设为首页 收藏本站
查看: 861|回复: 0

[经验分享] python模块:re模块

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2016-4-19 09:22:07 | 显示全部楼层 |阅读模式
.       匹配任意字符
[]      匹配指定字符类别
^       字符开头
$       字符结尾
[^]     取非字符
*       重复多次字符(0次或多次)
+       重复多次字符(1次或多次)
?       重复单次字符
|       左右表达式任意匹配
{m,n}   重复m到n次字符
{m}     重复m次字符  

\d      匹配任何十进制数,相当于[0-9]
\D      匹配任何非数字字符,相当于[^0-9]
\s      匹配任何空白字符,相当于[fdss]
\S      匹配任何非空白字符,相当于[^jdvnjsd]
\w      匹配任何数字字母,相当于[a-zA-Z0-9]
\W      匹配任何非数字字母,相当于[^a-zA-Z0-9]


例1:定义简单的正则表达式
格式:re.compile(strPattern[, flag]):

strPattern:字符串表达式
flag:
       re.I(re.IGNORECASE): 忽略大小写(括号内是完整写法,下同)
           M(MULTILINE): 多行模式,改变'^'和'$'的行为
           S(DOTALL): 点任意匹配模式,改变'.'的行为
           L(LOCALE): 使预定字符类 \w \W \b \B \s \S 取决于当前区域设定
           U(UNICODE): 使预定字符类 \w \W \b \B \s \S \d \D 取决于unicode定义的字符属性
           X(VERBOSE): 详细模式。这个模式下正则表达式可以是多行,忽略空白字符,并可以加入注释。
pattern=re.compile(r'heLLow',re.I)          #生成一个pattern实例
match=pattern.match('hellow world')    #使用pattern匹配文本

if match:
   print match.group()   #如果匹配就输出

#例2:match属性和方法
#!/bin/env python
#!-*- coding:UTF-8 -*-

import re

match=re.match(r'(\w+)(\w+)(?P<sign>.*)','hellow world!')    #使用pattern匹配文本
print "match.string:",match.string            #匹配时使用的文本
print "match.re:",match.re                    #匹配时使用的pattern对像
print "match.pos:",match.pos                  #开始搜索的索引
print "match.endpos:",match.endpos            #结束搜索的索引
print "match.lastindex:",match.lastindex      #最后一个被捕获在分组在文本中的索引
print "match.lastgroup",match.lastgroup       #最后一个被捕获的分组名
print "match.group(1,2):",match.group(1,2)    #获得一个或多个分组截获的字符串
print "match.groups():",match.groups()        #以元组形式返回全部分组的字符串
print "match.groupdict():",match.groupdict()  #返回有别名组的别名为键
print "match.start(2):",match.start(2)        #返回指定组截获的子串在字符中的起始索引
print "match.end(2):",match.end(2)            #返回指定组截获的子串在字符中的结束索引
print "match.span(2):",match.span(2)          #返回起始组和结束组


#例3:re模块和方法
re.compile            #转换为Pattern对像
re.match              #匹配正零时表达式
re.search             #查找字符串
re.split              #分割字符串
re.findall            #搜索字符中,以列表形式返回全部能匹配的子串
re.finditer           #搜索字符串,返回一个顺序访问每一个匹配的结果
re.sub                #替换字符串
re.subn               #替换字符串,n次

#例4:查找字符串
a=re.compile(r'hello')
b=a.search('hello world')   #查找a中是否有hello字符

if b:
   print b.group()

#例5:截断字符串
p=re.compile(r'\d')
print p.findall('one1two2three3four4five5')

#例6:返回每个匹配的结果
w=re.compile(r'\d')
for m in w.finditer('one1two2three3four4five5'):
    print m.group()

#例7:
e=re.compile(r'(\w+)(\w+)')
s='This is, tong cheng'

print e.sub(r'\2\1',s)
def func(m):
     return m.group(1).title()+ ' ' + m.group(2).title()
print e.sub(func,s)


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-205945-1-1.html 上篇帖子: python升级后yum不能使用报错 File “/usr/bin/yum”, line 30 下篇帖子: python脚本监控zabbix python
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表