字符串拼接
实际场景:把列表中的数据拼接成一个字符串
解决方案:使用 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,fdf.fss*dfd;fs:uu}fsd"
1.使用 python 中的 split() 方法,由于 split 一次处理一个分隔符,例如:
>>> res = s.split(';')>>> res['ab', 'fd/ft|fs,fdf.fss*dfd', 'fs:uu}fsd']
所以我们需要根据字符串中的分隔符,依次分割,可以是 map 函数!
>>> list(map(lambda x: x.split("|"), res))[['ab'], ['fd/ft', 'fs,fdf.fss*dfd'], ['fs:uu}fsd']]
结果变成了一个二维列表,而我们想要的结果是一维列表,怎么办?
创建一个临时列表保存结果。
'''遇到问题没人解答?小编创建了一个Python学习交流QQ群:895797751 寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!'''>>> t = []>>> list(map(lambda x: t.extend(x.split("|")), res))[None, None, None]>>> t['ab', 'fd/ft', 'fs,fdf.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,fdf.fss*dfd;fs:uu}fsd"print(my_split(s, ";/|,.}:*"))运行结果:['ab', 'fd', 'ft', 'fs', 'f', 'df', 'fss', 'dfd', 'fs', 'uu', 'fsd']
2.使用 re 模块的中 split() 方法
re() 也给我们提供了 split() 方法,可以一次性分隔字符串!
import res = "ab;fd/ft|fs,fdf.fss*dfd;fs:uu}fsd"print(re.split('[;/|,.}:*]', 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