Python的字符串处理,在爬虫的数据解析、大数据的文本清洗,以及普通文件处理等方面应用非常广泛,而且Python对字符串的处理内置了很多高效的函数,功能非常强大、使用非常方便。今天我就把字符串处理时用到最多的方法总结分享给大家,希望大家可以轻松应对字符串处理。
1.字符串的切片和相乘
(1)切片
str='Monday is a busy day' print(str[0:7]) #表示取第一个到第七个的字符串 print(str[-3:]) #表示取从倒数第三个字符开始到结尾的字符串 print(str[::]) #复制字符串
(2)相乘
当我们编写Python代码时要分隔符,此时用字符串的乘法操作就很容易实现。
line='*'*30 print(line) ******************************
2.字符串的分割
(1)普通的分割,用split函数,但是split只能做非常简单的分割,而且不支持多个分隔。
phone='400-800-800-1234' print(phone.split('-')) ['400', '800', '800', '1234']
(2)复杂的分割,r表示不转义,分隔符可以是「;」,或者「,」,或者空格后面跟0个多个额外的空格,然后按照这个模式去分割。
line='hello world; python, I ,like, it' import re print(re.split(r'[;,s]\s*',line)) >['hello world', 'python', 'I ', 'like', 'it']
3.字符串的连接和合并
(1)连接,两个字符可以很方便的通过“+”连接起来
str1='Hello' str2='World' new_str=str1+str2 print(new_str) >HelloWorld
(2)合并,用join方法
url=['www','python','org'] print('.'.join(url)) >www.python.org
4.判断字符串是否以指定前缀、后缀结尾
假设我们要查一个文件的名字是以什么开头或者什么结尾"htmlcode">
filename='trace.h' print(filename.endswith('h')) True print(filename.startswith('trace')) True
5.字符串的查找和匹配
(1)一般查找
利用find方法可以很方便的在长的字符串里面查找子字符串,会返回字符串所在位置的索引,若找不到返回-1
str1 = "this is string example....wow!!!" str2 = "exam" print(str1.find(str2)) # 15 print(str1.find(str2, 10)) # 15 print(str1.find(str2, 40)) # -1
(2)复杂的匹配,就需要用到正则表达式。
mydate='11/27/2016' import re if re.match(r'\d+/\d+/\d+',mydate): print('ok.match') else: print('not match') >ok.match
6.统计字符串里某个字符出现的次数
str = "thing example....wow!!!" print(str.count('i', 0, 5)) # 1 print(str.count('e')) # 2
7.字符串的替换
(1)普通的替换,用replace方法就可以了
text='python is an easy to learn,powerful programming language.' print(text.replace('learn','study')) >python is an easy to study,powerful programming language.
(2)复杂的替换,需要用到re模块的sub函数
students='Boy 103,girl 105' import re print(re.sub(r'\d+','100',students)) >Boy 100,girl 100
8.去掉字符串中一些特定的字符
(1)去空格,对文本处理的时候比如从文件中读取一行,然后需要去除每一行的空格、table或者是换行符。
str = ' python str ' print(str) # 去首尾空格 print(str.strip()) # 去左侧空格 print(str.lstrip()) # 去右侧空格 print(str.rstrip())
(2)复杂的文本清理,可以利用str.translate。
比如先构建一个转换表,table是一个翻译表,表示把“to”转成大写的“TO”,然后在old_str里面去掉‘12345',然后剩下的字符串再经过table翻译。
instr = 'to' outstr = 'TO' old_str = 'Hello world , welcome to use Python. 123456' remove = '12345' table = str.maketrans(instr,outstr,remove) new_str = old_str.translate(table) print(new_str) >HellO wOrld , welcOme TO use PyThOn. 6
总结
平时我们使用Python都是处理一些脚本,其中使用频率最大的就是字符串的处理方面,因此给大家整理了这些常用的字符串处理时使用的方法,希望对大家有用。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新日志
- 魔兽世界wlk敏锐贼一键输出宏是什么 wlk敏锐贼一键输出宏介绍
- 李逸朗2007-李威乐[英皇娱乐][WAV+CUE]
- DavidVersace-EyetoEye(2024)[24-44,1]
- SimoneLamsma,RobertKulek-Mendelssohn,Janacek,Schumann-SonatasforViolinandPiano【SAC
- 《街头篮球》大动作:新增五大服务器节点 优化玩家体验
- 任天堂宣布推出音乐APP!仅面向NSO订阅用户
- 《马路RPG:兄弟齐航》新预告!兄弟携手海岛冒险
- 王子鸣.2009-永远【九洲】【WAV分轨】
- 杭天琪.2002-水与火的缠绵【泰达】【WAV+CUE】
- 邱锋泽.2024-COlOR.Free【发现梦想】【FLAC分轨】
- 群星 《10年朋友Vol.8》滚石台湾版[WAV+CUE][1.G]
- 群星《2024好听新歌31》十倍音质 U盘音乐 [WAV分轨][1.1G]
- 群星《全天后》华纳[WAV+CUE][1.1G]
- 许乐《声愿HQCD》[正版原抓WAV+CUE]
- 黄凯芹《给你留念》头版限量编号MQA-UHQCD2024[低速原抓WAV+CUE]