这篇文章主要介绍“Python怎么以不区分大小写的方式对文本做查找和替换”,在日常操作中,相信很多人在Python怎么以不区分大小写的方式对文本做查找和替换问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Python怎么以不区分大小写的方式对文本做查找和替换”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
1、需求
我们需要以不区分大小写的方式在文本中进行查找,可能还需要做替换。
2、解决方案
要进行不区分大小写的文本操作,我们需要使用re模块并且对各种操作都要加上re.IGNORECASE标记。
示例:
import re text='Mark is a handsome guy and mark is only 18 years old.' result1=re.findall('mark',text,flags=re.IGNORECASE) result2=re.sub('mark','python',text,flags=re.IGNORECASE) print(result1) print(result2)
结果:
['Mark', 'mark'] python is a handsome guy and python is only 18 years old.
上面例子揭示了一种局限,就是虽然名字从【mark】替换为【python】,但是大小写并不吻合,例如第一个人名替换后应该也是大写:【Pyhton】。
如果想要修正这个问题,需要用到一个支撑函数,实例如下:
import re text='Mark is a handsome guy and mark is only 18 years old.MARK' def matchcase(word): def replace(m): #re.sub会将匹配到的对象,循环调用replace方法传入 print(m) #获取匹配的文本 text=m.group() if text.isupper(): #如果文本全部是大写,就返回word的全部大写模式 return word.upper() elif text.islower(): # 如果文本全部是小写,就返回word的全部小写模式 return word.lower() elif text[0].isupper(): #如果文本是首字母大写,就返回word的首字母大写模式 return word.capitalize() else: #其他情况,直接返回word return word return replace result=re.sub('mark',matchcase('python'),text,flags=re.IGNORECASE) print(result)
运行结果:
<re.Match object; span=(0, 4), match='Mark'> <re.Match object; span=(27, 31), match='mark'> <re.Match object; span=(53, 57), match='MARK'> Python is a handsome guy and python is only 18 years old.PYTHON
3、分析
对于简单的情况,只需加上re.IGNORECASE标记足以进行不区分大小写的匹配操作了。
到此,关于“Python怎么以不区分大小写的方式对文本做查找和替换”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。