本文要点
- 字符串拼接
- 拆分含有多种分隔符的字符串
- 判读字符串a是否以字符串b开头或结尾
- 调整字符串中文本的格式
- 对字符串进行左,右,居中对齐
- 删除字符串中不需要的字符
Python资源共享群:484031800
实际场景:把列表中的数据拼接成一个字符串
解决方案:使用 str.join() 方法
>>> li = ['cxk', 'cxk', 'kk', 'caibi']>>> ''.join([str(i) for i in li])'cxkcxkkkcaibi'推荐使用生成器表达式,如果列表很大,可以节省很多内存空间
>>> ''.join(str(i) for i in li)'3cxkkkcaibi'拆分含有多种分隔符的字符串
实际场景:把某个字符串依据分割符号拆分不同的字段,该字符串包含多种不同的分隔符
s = "ab;fd/ft|fs,ftdf.fss*dfd;fs:uu}fsd"1.使用 python 中的 split() 方法,由于 split 一次处理一个分隔符,例如:
>>> res = s.split(';')>>> res['ab', 'fd/ft|fs,ftdf.fss*dfd', 'fs:uu}fsd']所以我们需要根据字符串中的分隔符,依次分割,可以是 map 函数!
>>> list(map(lambda x: x.split("|"), res))[['ab'], ['fd/ft', 'fs,ftdf.fss*dfd'], ['fs:uu}fsd']]结果变成了一个二维列表,而我们想要的结果是一维列表,怎么办?
创建一个临时列表保存结果 。
>>> t = []>>> list(map(lambda x: t.extend(x.split("|")), res))[None, None, None]>>> t['ab', 'fd/ft', 'fs,ftdf.fss*dfd', 'fs:uu}fsd']结果符合我们的预期!接下来继续处理剩余的分隔符,重复动作,用 for 循环搞定!
最终代码如下:
def my_split(s, ds): res = [s] for d in ds: t = [] list(map(lambda x: t.extend(x.split(d)), res)) res = t return res将字符串和字符串中所有的分隔符传入,结果如下:
s = "ab;fd/ft|fs,ftdf.fss*dfd;fs:uu}fsd"print(my_split(s, ";/|,.}:*t"))运行结果:['ab', 'fd', 'ft', 'fs', 'f', 'df', 'fss', 'dfd', 'fs', 'uu', 'fsd']
2.使用 re 模块的中 split() 方法
re() 也给我们提供了 split() 方法,可以一次性分隔字符串!
import res = "ab;fd/ft|fs,ftdf.fss*dfd;fs:uu}fsd"print(re.split('[;/|,.}:*t]', s))结果一致,是不是很简单粗暴!
判读字符串a是否以字符串b开头或结尾
实际场景:比如某目录下有一系列文件:

文章插图
编写程序给其中所有 .txt 文件和 .py 文件加上用户可执行权限
解决方案:
使用字符串 str.startswith() 和 str.endswith()
找出以 .txt 和 .py 结尾的文件,其接受一个元组
>>> import os>>> os.listdir(".")['App', 'config', 'requirements.txt', 'run.py', '__pycache__', 'gunicorn.conf.py', 'chromedriver', 'login_after2.png', 'readme.txt', 'slide.png', 'test.py', 'logs', 'chrome-linux.zip', 'gunicorn.pid', 'asgi.py', 'chrome-linux']>>> [name for name in os.listdir(".") if name.endswith((".txt", ".py"))]['requirements.txt', 'run.py', 'gunicorn.conf.py', 'readme.txt', 'test.py', 'asgi.py']调整字符串中文本的格式
实际案列:例如在日志文件中,其中日期格式为'yyyy-mm-dd':

文章插图
我们想把其中的日期改为美国日期格式'mm/dd/yyyy'.比如 2019-06-12 改成 06/12/2019 格式
解决方案:使用 re 中的 sub() 方法做字符串替换
利用正则表达式中的捕获组,捕获每个部分的内容,然后在替换在替换的字符串中调整各个捕获组的顺序!
代码如下:
import rewith open("info.log", "r", encoding="utf-8") as f: file = f.read()print(re.sub('(d{4})-(d{2})-(d{2})', r'2/3/1', file))捕获组中每组需要用括号括起来,然后默认从左至右分为组1, 组2…
下一个参数是我们要替换的格式,用 1,2,3 分别表示组1, 组2…
运行结果如下:

文章插图
对字符串进行左,右,居中对齐
解决方案:
1.使用字符串中的 str.ljust(), str.rjust(), str.center() 进行左右居中对齐!
推荐阅读
- 140种Python标准库、第三方库和外部工具都有了
- Python函数式编程,Python闭包
- Python接口测试自动化实战及代码示例:含get、post等方法
- 教你如何优雅地用Python连接MySQL数据库
- 详细的介绍香醇红茶的泡法
- 超详细的mysql数据库修改InnoDB redo log日志大小教程
- 基于python语言的大数据搜索引擎
- 常见加密方式和Python实现
- 最靠谱最好吃最详细的万能辣椒酱 自制辣椒酱
- 简单函数与温度转换 业余码农成长记——Python学习4