圆月山庄资源网 Design By www.vgjia.com

反斜杠的作用:

要想将一个元字符^当一个普通字符处理,加反斜杠

例如:

>import re
>r=r'\^abc'
>re.findall(r,'^abc ^abc ^abc')
['^abc','^abc','^abc']

\d匹配任何十进制数,它相当于类[0-9].
\D匹配任何非数字字符,它相当于类[^0-9]
\s匹配任何空白字符,他相当于类[\t\n\r\f\v]
\S匹配任何非空白字符,它相当于类[^\t\n\r\f\v]
\w匹配任何字母数字字符,它相当于类[a-zA-Z0-9_]
\W匹配任何非字母数字字符,它相当于类[^a-zA-Z0-9_]

>r=r'[0-9]'
>re.findall(r,'1234567890')
['1','2','3','4','5','6','7','8','9','0']

>r=r'\d'
>re.findall(r,'1234567890')
['1','2','3','4','5','6','7','8','9','0']
>r=r'^010-\d\d\d\d\d\d\d\d'
>re.findall(r,'010-87654321')
['010-87654321']
>re.findall(r,'010-8765432')
[]

>r=r'^010-\d{8}'#重复八次
>re.findall(r,'010-12345678')
['^010-12345678']

星号的作用:(*)

将前面的一个字符匹配零次或更多次。

>r=r'ab*'
>re.findall(r,'a')
['a']
>re.findall(r,'ab')
['ab']
>re.findall(r,'abbbbbb')
['abbbbbb']

加号的作用:(+)

表示匹配一次或更多次。

>r=r'ab+'
>re.findall(r,'a')
[]
>re.findall(r,'ab')
['ab']
>re.findall(r,'abbbb')
['abbbb']

电话号码中间的“-”问题:(可有可无)

>r=r'^010-*\d{8}'
>re.findall(r,'010-12345678')
['010-12345678']
>re.findall(r,'01012345678')
['01012345678']
>re.findall(r,'010---12345678')
['010---12345678']

问号的作用:(?)

匹配一次或零次;

>r=r'^010-"htmlcode">
>r=r'ab+'
>re.findall(r,'abbbbbbbbbbb')
['abbbbbbbbbbb']

非贪婪模式匹配,用问号做最小匹配,如下:

>r=r'ab+"htmlcode">
>r=r'a{1,3}'#表示a重复一到三次
>re.findall(r,'a')
['a']
>re.findall(r,'aa')
['aa']
>re.findall(r,'aaa')
['aaa']
>re.findall(r,'aaaa')
['aaa','a']

分组:“(”和“)”

> import re
> email=r'\w{3}@\w+(\.com|\.cn)'#定义正则,(\.com|\.cn)表示一个分组;分组中做**或**操作,要么是.com,要么是.cn
> re.match(email,'www@owolf.com')#进行匹配
<_sre.SRE_Match object; span=(0, 13), match='www@owolf.com'>
> re.match(email,'www@owolf.cn')
<_sre.SRE_Match object; span=(0, 12), match='www@owolf.cn'>
> re.match(email,'www@owolf.org')
>  #返回空值
> re.findall(email,'www@owolf.com')
['.com']      #做匹配的时候优先返回分组中的数据
> re.findall(email,'www@owolf.cn')
['.cn']
> 
> s='''
ajhfa kasjf owolf english=chinese yes  no print
lafl int=456 yes float
int=789 yes
owolf english=france yes  aklfl
'''#定义字符串
> r=r'owolf english=.+ yes' #定义正则
> re.findall(r,s)    #匹配正则
['owolf english=chinese yes', 'owolf english=france yes']     
> r=r'owolf english=(.+) yes'
> re.findall(r,s)
['chinese', 'france'] #利用分组优先返回分组中的数据,在爬虫中经常应用

总结

以上就是本文关于Python元字符的用法实例解析的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!

标签:
python,元字符,python,字符解析,python中字符串的用法

圆月山庄资源网 Design By www.vgjia.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
圆月山庄资源网 Design By www.vgjia.com

P70系列延期,华为新旗舰将在下月发布

3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。

而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?

根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。