Python二分查找+字符串模板+textwrap模块,

 更新时间:2022年05月16日 11:38:55   作者:​ 梦想橡皮擦   ​  
这篇文章主要介绍了Python二分查找+字符串模板+textwrap模块,文章围绕主题展开详细内容,具有一定的参考价值,需要的小伙伴可以参考一下

前言:

这个系列的专栏是为了保持 Python 手感而创建的,也可以用来学习 Python,因为存在知识跨越难度,所以先学习滚雪球系列为佳。

二分查找

问题场景 在一个升序的数组中(其实就是一个只有整数的列表),查找一个目标数的下标,不存在返回 -1 。

解决思路 因为数组是升序的,所以二分查找就能落地了 先取出数组中的中间值,与目标数比较大小,确定一半的范围 然后重复上述步骤不断缩小范围即可。

编码如下:

def search(nums, start, end, target):
    if start > end:
        return -1
    # 获取中间值
    mid = (start + end) // 2
    # 比较中间值与目标数的大小关系
    if nums[mid] > target:  # 中值大于目标数据,目标数在左侧
        return search(nums, start, mid, target)
    if nums[mid] == target:  # 中值等于目标数据,返回
        return mid
    if nums[mid] < target:  # 中值小于目标数据,目标数在右侧
        return search(nums, mid, end, target)
if __name__ == '__main__':
    ret = search([1, 2, 3, 4], 0, 4, 1)
    print(ret)

字符串模板

问题场景 + 拼接字符串会让代码变得难以阅读,是否存在其它办法可以将字符串进行格式化?

解决思路 Python 字符串允许出现占位符,然后再通过特定的代码将占位符替换掉。

编码如下:

import string
tp1 = string.Template('你正在阅读$name的博客')
tp2 = string.Template('你正在阅读${name}的博客')
s1 = tp1.substitute(name="橡皮擦")
s2 = tp2.substitute(name="橡皮擦")
print(s1)
print(s2)

其中 $ 是占位符开头的特殊符号,如果字符串本身也存在 $ 符号,需要使用 $$ 代替。 字符串模板使用的是 string 模块中的 Template 类,替换字符串需要调用对象的 substitute() 方法。 需要特别注意的是如果 substitute() 方法中的参数数量与模板中不一致,Python编译器也不会抛出错误。

import string
tp1 = string.Template('你正在阅读$name的博客')
s1 = tp1.substitute(name="橡皮擦", age=18) # 参数不一致,不会出现错误
print(s1)

但反之如果字符串模板中存在一个占位符,但是 substitute() 方法中没有提供,就会抛出异常。

import string
tp1 = string.Template('你正在阅读$name的博客')
tp2 = string.Template('你正在阅读${name}$age的博客')
s1 = tp1.substitute(name="橡皮擦", age=18)  # 参数不一致,不会出现错误
s2 = tp2.substitute(name="橡皮擦")  # 但是这样确发生错误
s3 = tp2.safe_substitute(name="橡皮擦")
print(s1)
print(s2)
print(s3)

解决上述问题的办法,就是使用 字符串模板类中提供的另一个 safe_substitute() 方法,代码如下

import string
tp1 = string.Template('你正在阅读$name的博客')
tp2 = string.Template('你正在阅读${name}$age的博客')
# s2 = tp2.substitute(name="橡皮擦")  # 但是这样确发生错误
s3 = tp2.safe_substitute(name="橡皮擦") # 不会报错
# print(s2)
print(s3)

textwrap 模块

问题场景 Python中可以对文本,即字符串进行更加细致的操作,例如自动换行,填充字符。

解决思路 使用 textwrap 模块进行操作。 首先使用 help() 函数查看该模块具有哪些类与方法。

模块内具备类 TextWrapper(builtins.object) ,具备如下方法:

  • dedent(text):移除 text 中每一行的任何相同前缀空白符;
  • fill(text, width=70, **kwargs):将单个段落包装在 text 中,并返回包含已包装段落的单个字符串,fill() 和 wrap() 方法类似,分割结果相同,但返回结果形式不同,它的作用就是在分割的片段之间添加 \n ,然后将其重新变成一个文本进行输出;
  • indent(text, prefix, predicate=None):将 prefix 添加到 text 中选定行的开头;
  • shorten(text, width, **kwargs):在 text 中截取给定 width 的字符;
  • wrap(text, width=70, **kwargs):将 text 中的单个段落(字符串)换行,每一行最多为 width 个字符长。返回输出行列表,不带最终换行符。

编码如下 textwrap.wrap()

import textwrap
text = "你好, 我是橡皮擦  这是Python学习的第2天"
result = textwrap.wrap(text,10)
print(result)

输出结果如下:

textwrap.fill()

import textwrap
text = "你好, 我是橡皮擦  这是Python学习的第2天"
result = textwrap.fill(text,10)
print(result)

textwrap.dedent(text) 该方法可以移除不需要的前缀空格。可以用来使三引号的字符串与显示的左边缘对齐,同时仍然以缩进的形式在源代码中显示。

import textwrap
text = '''
    大家好
                    我是橡皮擦
    这是大家的Python博客'''
print(text)
print("*"*100)
print(textwrap.dedent(text))

运行结果如下:

textwrap.indent()

import textwrap
sample_text = '''
    你好,我是橡皮擦
    这是我的博客
    写作的内容都是 Python
    希望得到你的关注
    '''
dedented_text = textwrap.dedent(sample_text)
final = textwrap.indent(dedented_text, '> ')
print(final)

运行结果如下:

按照空格统计词组个数

问题场景 一个段落,例如 "我 是 橡皮擦,这 是 大家 的 Python 博客",统计出有多少词组。

解决思路 通过判断字符的前一字符是空格进行判断。

编码如下

class Ca:
    def phrase_count(self, p):
        c = 0 # 统计个数
        for i in range(len(p)):
            # 如果当前字符不为空格并且不是第一位或者前一字符不是空格
            if p[i] != ' ' and (i == 0 or p[i - 1] == ' '):
                # 加1
                c += 1
        return c
if __name__ == '__main__':
    c = Ca()
    p = '我 是 橡皮擦,这 是 大家 的 Python 博客'
    print(f"词组个数是:{c.phrase_count(p)}")

用 “0” 填充字符串

问题场景 在字符串前面填充占位符 0 。

解决思路 使用 zfill() 方法返回指定长度的字符串,原字符串右对齐,前面填充 0

编码时间

str = "橡皮擦的博客"
print(str.zfill(20))
print(str.zfill(30))

到此这篇关于Python二分查找+字符串模板+textwrap模块,的文章就介绍到这了,更多相关Python 基础内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • python中的deque基本用法详解

    python中的deque基本用法详解

    Python 中的 deque是一个低级别的、高度优化的双端队列,对于实现优雅、高效的Pythonic队列和堆栈很有用,这篇文章主要介绍了python中的deque基本用法的相关资料,需要的朋友可以参考下
    2017-11-11
  • Python object类中的特殊方法代码讲解

    Python object类中的特殊方法代码讲解

    在本篇文章里小编给各位整理了关于Python object类中的特殊方法代码讲解,需要的朋友们可以参考下。
    2020-03-03
  • Python实现批量检测ip地址连通性

    Python实现批量检测ip地址连通性

    这篇文章主要为大家详细介绍了如何使用Python实现批量检测ip地址连通性并以json格式显示(支持传参单IP或者网段),感兴趣的小伙伴可以了解下
    2024-04-04
  • Python基础知识_浅谈用户交互

    Python基础知识_浅谈用户交互

    下面小编就为大家带来一篇Python基础知识_浅谈用户交互。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-05-05
  • 使用python实现ftp的文件读写方法

    使用python实现ftp的文件读写方法

    今天小编就为大家分享一篇使用python实现ftp的文件读写方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-07-07
  • python opencv实现信用卡的数字识别

    python opencv实现信用卡的数字识别

    这篇文章主要介绍了python opencv实现信用卡的数字识别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-01-01
  • 使用Python实现为PDF文档设置和移除密码

    使用Python实现为PDF文档设置和移除密码

    在数字化时代,文档的安全性变得越来越重要,特别是对于包含敏感信息的PDF文件,所以本文主要来和大家介绍一下如何使用Python实现为PDF文档设置和移除密码,需要的可以参考下
    2024-03-03
  • Python批量修改文件名实例操作分享

    Python批量修改文件名实例操作分享

    这篇文章主要介绍了Python批量修改文件名实例操作分享,问咋还那个主要通过以修改图片文件名为例,将图片复制到新的目录中再修改名称,下文详细操作过程需要的小伙伴可以参考一下
    2022-04-04
  • Pandas数据分析之pandas文本处理

    Pandas数据分析之pandas文本处理

    这篇文章主要介绍了Pandas数据分析之pandas文本处理,pandas对文本数据也有很多便捷处理方法,可以不用写循环,向量化操作运算速度快,还可以进行高级的正则表达式,各种复杂的逻辑筛选和匹配提取信息
    2022-08-08
  • 总结Python函数参数的六种类型

    总结Python函数参数的六种类型

    这篇文章主要总结了Python函数参数的六种类型,传递参数实现不同场景的灵活使用,下面总结的六种函数参数类型,需要的小伙伴可以参考一下
    2022-03-03

最新评论