Python超详细的字符串⽤法⼤全
字符串拼接
实际场景:把列表中的数据拼接成⼀个字符串
解决⽅案:使⽤ 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,f\tdf.fss*dfd;fs:uu}fsd"
1.使⽤ python 中的 split() ⽅法,由于 split ⼀次处理⼀个分隔符,例如:
>>> res = s.split(';')
>>> res
['ab', 'fd/ft|fs,f\tdf.fss*dfd', 'fs:uu}fsd']
所以我们需要根据字符串中的分隔符,依次分割,可以是 map 函数!
>>> list(map(lambda x: x.split("|"), res))
[['ab'], ['fd/ft', 'fs,f\tdf.fss*dfd'], ['fs:uu}fsd']]
结果变成了⼀个⼆维列表,⽽我们想要的结果是⼀维列表,怎么办?
创建⼀个临时列表保存结果。
# Python学习交流QQ:857662006
>>> t = []
递归函数特点>>> list(map(lambda x: t.extend(x.split("|")), res))
[None, None, None]
>>> t
['ab', 'fd/ft', 'fs,f\tdf.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,f\tdf.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() ⽅法,可以⼀次性分隔字符串!
weblogic打补丁import repython基础代码大全下载
s = "ab;fd/ft|fs,f\tdf.fss*dfd;fs:uu}fsd"
print(re.split('[;/|,.}:*\t]', s))
结果⼀致,是不是很简单粗暴!
access数据库程序设计是考什么判读字符串a是否以字符串b开头或结尾
实际场景:⽐如某⽬录下有⼀系列⽂件:
编写程序给其中所有 .txt ⽂件和 .py ⽂件加上⽤户可执⾏权限
解决⽅案:
使⽤字符串 str.startswith() 和 dswith()
出以 .txt 和 .py 结尾的⽂件,其接受⼀个元组
>>> import os
>>> os.listdir(".")
['app', 'config', '', 'run.py', '__pycache__', 'f.py', 'chromedriver', 'login_after2.png', '', 'slide.png', 'test.py', 'logs', 'chrome-linux.zip', 'gunicorn.pid', 'asgi.py', 'chrome-linux'] >>> [name for name in os.listdir(".") dswith((".txt", ".py"))]
['', 'run.py', 'f.py', '', 'test.py', 'asgi.py']
调整字符串中⽂本的格式
实际案列:例如在⽇志⽂件中,其中⽇期格式为'yyyy-mm-dd':
我们想把其中的⽇期改为美国⽇期格式'mm/dd/yyyy'.⽐如 2019-06-12 改成 06/12/2019 格式
解决⽅案:使⽤ re 中的 sub() ⽅法做字符串替换
利⽤正则表达式中的捕获组,捕获每个部分的内容,然后在替换在替换的字符串中调整各个捕获组的顺序!
代码如下:
import re
with 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…
运⾏结果如下:
对字符串进⾏左,右,居中对齐
解决⽅案:unity3d能免费使用吗
1.使⽤字符串中的 str.ljust(), str.rjust(), () 进⾏左右居中对齐!以上三种⽅法的基本⽤法:
>>> s = 'abc'
>>> s.ljust(20, '=')
'abc================='
>>> s.ljust(20)
'abc          '
三种⽅法都可以设置默认填充值
2.使⽤内置的 format() ⽅法
php技术社区>>> format(s, ">20")
'                abc'
>>> format(s, "<20")
'abc                '
>>> format(s, "^20")
'        abc        '
删除字符串中不需要的字符
实际案例:
过滤掉⽤户输⼊中前后多余的空⽩字符:“ nick2008@gmail ”
过滤掉某 windows 下编辑⽂本中的 “\r” :“hello world \r\n”
去掉⽂本中的 unicode 组合符号(⾳调):nǐ hǎo mā
解决⽅案:
使⽤ str.strip(), str.lstrip(), str.rstrip() ⽅法去掉字符串两端字符
使⽤ place() 或者正则中的 re.sub()
使⽤字符串中 anslate() ⽅法,可以同时删除多个不同的字符

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。