Python字符串及文本模式方法详解


Posted in Python onSeptember 10, 2020

一、你想在字符串中搜索和匹配指定的文本模式

遗漏点:re模块其实也是帮助我们进行字符串处理的重要工具,我之前总是想着用内建的函数来处理,其实如果是复杂的文本和数据结构,re模块能帮助我们处理很多信息。

对于简单的字面模式,直接使用 str.replace() 方法即可,比如:

>>> text = 'yeah, but no, but yeah, but no, but yeah'
>>> text.replace('yeah', 'yep')
'yep, but no, but yep, but no, but yep'
>>>

对于复杂的模式,请使用 re 模块中的 sub() 函数。 为了说明这个,假设你想将形式为 11/27/2012 的日期字符串改成 2012-11-27 。示例如下:

>>> text = 'Today is 11/27/2012. PyCon starts 3/13/2013.'
>>> import re
>>> re.sub(r'(\d+)/(\d+)/(\d+)', r'\3-\1-\2', text)
'Today is 2012-11-27. PyCon starts 2013-3-13.'

二、你需要以忽略大小写的方式搜索与替换文本字符串

为了在文本操作时忽略大小写,你需要在使用 re 模块的时候给这些操作提供 re.IGNORECASE 标志参数。比如:

>>> text = 'UPPER PYTHON, lower python, Mixed Python'
>>> re.findall('python', text, flags=re.IGNORECASE)
['PYTHON', 'python', 'Python']
>>> re.sub('python', 'snake', text, flags=re.IGNORECASE)
'UPPER snake, lower snake, Mixed snake'

最后的那个例子揭示了一个小缺陷,替换字符串并不会自动跟被匹配字符串的大小写保持一致。 为了修复这个,你可能需要一个辅助函数,就像下面的这样:

def matchcase(word):
  def replace(m):
    text = m.group()
    if text.isupper():
      return word.upper()
    elif text.islower():
      return word.lower()
    elif text[0].isupper():
      return word.capitalize()
    else:
      return word
  return replace

>>> re.sub('python', matchcase('snake'), text, flags=re.IGNORECASE)
'UPPER SNAKE, lower snake, Mixed Snake'

matchcase('snake') 返回了一个回调函数(参数必须是 match 对象),sub() 函数除了接受替换字符串外,还能接受一个回调函数。

三、你正在试着使用正则表达式去匹配一大块的文本,而你需要跨越多行去匹配

>>> comment = re.compile(r'/\*(.*?)\*/')
>>> text1 = '/* this is a comment */'
>>> text2 = '''/* this is a
... multiline comment */
... '''
>>>
>>> comment.findall(text1)
[' this is a comment ']
>>> comment.findall(text2)

re.compile() 函数接受一个标志参数叫 re.DOTALL ,在这里非常有用。 它可以让正则表达式中的点(.)匹配包括换行符在内的任意字符。比如:

>>> comment = re.compile(r'/\*(.*?)\*/', re.DOTALL)
>>> comment.findall(text2)
[' this is a\n multiline comment '] 

四、你想通过某种对齐方式来格式化字符串

于基本的字符串对齐操作,可以使用字符串的 ljust() , rjust() 和 center() 方法。比如:

>>> text = 'Hello World'
>>> text.ljust(20)
'Hello World '
>>> text.rjust(20)
' Hello World'
>>> text.center(20)
' Hello World '
>>> text.rjust(20,'=')
'=========Hello World'
>>> text.center(20,'*')
'****Hello World*****'
>>>

函数 format() 同样可以用来很容易的对齐字符串。 你要做的就是使用 <,> 或者 ^ 字符后面紧跟一个指定的宽度。比如:

>>> format(text, '>20')
' Hello World'
>>> format(text, '<20')
'Hello World '
>>> format(text, '^20')
' Hello World '
>>>

如果你想指定一个非空格的填充字符,将它写到对齐字符的前面即可:

>>> format(text, '=>20s')
'=========Hello World'
>>> format(text, '*^20s')
'****Hello World*****'
>>>

当格式化多个值的时候,这些格式代码也可以被用在 format() 方法中。比如:

>>> x = 1.2345
>>> format(x, '>10')
' 1.2345'
>>> format(x, '^10.2f')
' 1.23 '
>>>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Pyhton中防止SQL注入的方法
Feb 05 Python
在Python中使用lambda高效操作列表的教程
Apr 24 Python
python制作企业邮箱的爆破脚本
Oct 05 Python
JSON Web Tokens的实现原理
Apr 02 Python
Python编程之gui程序实现简单文件浏览器代码
Dec 08 Python
Python subprocess库的使用详解
Oct 26 Python
Python爬虫实现验证码登录代码实例
May 10 Python
logging level级别介绍
Feb 21 Python
python实现输入三角形边长自动作图求面积案例
Apr 12 Python
pytorch 查看cuda 版本方式
Jun 23 Python
Python random模块的使用示例
Oct 10 Python
python 使用cycle构造无限循环迭代器
Dec 02 Python
python raise的基本使用
Sep 10 #Python
Python常用数字处理基本操作汇总
Sep 10 #Python
Python通用唯一标识符uuid模块使用案例
Sep 10 #Python
Python编写单元测试代码实例
Sep 10 #Python
python super()函数的基本使用
Sep 10 #Python
Python如何实现机器人聊天
Sep 10 #Python
Python 必须了解的5种高级特征
Sep 10 #Python
You might like
建立动态的WML站点(二)
2006/10/09 PHP
php数据库备份还原类分享
2014/03/20 PHP
美图秀秀web开放平台--PHP流式上传和表单上传示例分享
2014/06/22 PHP
dess中一个简单的多路委托的实现
2010/07/20 Javascript
将Datatable转化成json发送前台实现思路
2013/09/06 Javascript
event对象获取方法总结在google浏览器下测试
2013/11/03 Javascript
javascript中with()方法的语法格式及使用
2014/08/04 Javascript
基于jQuery实现左右图片轮播(原理通用)
2015/12/24 Javascript
js实现楼层效果的简单实例
2016/07/15 Javascript
第一个Vue插件从封装到发布
2017/11/22 Javascript
JS实现的将html转为pdf功能【基于浏览器端插件jsPDF】
2018/02/06 Javascript
JS中的JSON对象的定义和取值实现代码
2018/05/09 Javascript
浅谈KOA2 Restful方式路由初探
2019/03/14 Javascript
Vue.js中Line第三方登录api的实现代码
2020/06/29 Javascript
JS实现鼠标按下拖拽效果
2020/07/23 Javascript
[02:59]DOTA2完美大师赛主赛事第三日精彩集锦
2017/11/25 DOTA
Python(Tornado)模拟登录小米抢手机
2013/11/12 Python
10个易被忽视但应掌握的Python基本用法
2015/04/01 Python
Python单元测试框架unittest使用方法讲解
2015/04/13 Python
利用python批量给云主机配置安全组的方法教程
2017/06/21 Python
Python随机生成均匀分布在三角形内或者任意多边形内的点
2017/12/14 Python
python3爬取各类天气信息
2018/02/24 Python
python tkinter界面居中显示的方法
2018/10/11 Python
Python实现爬取马云的微博功能示例
2019/02/16 Python
pytorch实现对输入超过三通道的数据进行训练
2020/01/15 Python
Flask模板引擎Jinja2使用实例
2020/04/23 Python
python使用建议与技巧分享(一)
2020/08/17 Python
python 调用Google翻译接口的方法
2020/12/09 Python
纯CSS3制作漂亮带动画效果的主机价格表
2015/04/25 HTML / CSS
再婚婚前财产协议书范本
2014/10/19 职场文书
初中毕业生自我评价
2015/03/02 职场文书
个人年底工作总结
2015/03/10 职场文书
企业内部管理控制:采购授权审批制度范本
2020/01/19 职场文书
血轮眼轮回眼特效 html+css
2021/03/31 HTML / CSS
如何用python识别滑块验证码中的缺口
2021/04/01 Python
linux下安装redis图文详细步骤
2021/12/04 Redis