码迷,mamicode.com
首页 > 其他好文 > 详细

re模块

时间:2017-04-13 00:19:56      阅读:177      评论:0      收藏:0      [点我收藏+]

标签:art   code   span   http   class   arc   png   表达式   正则表达   

1、正则表达式的概念

正则表达式是用来简洁表达一组字串的表达式。

技术分享

正则表达式的语法

技术分享

技术分享

re库的基本使用

原生字符合以r开头,反指不包含转义符的字符串

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

 

import re

match1 = re.search(r[1-9]\d{5}, BIT 100081)
if match1:
    print(match1.group(0))  #100081

match2 = re.match(r[1-9]\d{5}, "100081 BIT ")
if match2:
    print(match2.group(0)) #100081

match3 = re.findall(r[1-9]\d{5},100081 BIT  BIT 100084)
print(match3) #[‘100081‘, ‘100084‘]

s = re.split(r[1-9]\d{5},BIT100081 BIT100084)
print(s)#[‘BIT‘, ‘ BIT‘, ‘‘]

s1 = re.split(r[1-9]\d{5},BIT100081 BIT100084,maxsplit=1)
print(s1)#[‘BIT‘, ‘ BIT100084‘]

for i in re.finditer(r[1-9]\d{5},BIT100081 BIT100084):
    if i:
        print(i.group(0)) #100081 100084

r = re.sub(r[1-9]\d{5}, :zcode, BIT100081 BIT100084)
print(r) #BIT:zcode BIT:zcode

技术分享

技术分享

技术分享

re库的Match对象

技术分享

技术分享

import re

match1 = re.search(r[1-9]\d{5}, BIT 100081)
print(match1.string) #BIT 100081
print(match1.re) #re.compile(‘[1-9]\\d{5}‘)
print(match1.pos) #0
print(match1.endpos) #10
print(match1.group(0)) #100081
print(match1.start()) #4
print(match1.end()) #10
print(match1.span()) #(4, 10)

re库的贪婪匹配和最小匹配

re库默认是贪婪匹配,输出匹配到的最长度符串

import re

match1 = re.search(rpy.*n, pyfdjklafjn)
if match1:
    print(match1.group(0)) #pyfdjklafjn

如何输出最小度符串

import re

match1 = re.search(rpy.*?n, pyfdjklafjn)
if match1:
    print(match1.group(0)) #pyfn

技术分享

技术分享

 

re模块

标签:art   code   span   http   class   arc   png   表达式   正则表达   

原文地址:http://www.cnblogs.com/jp-mao/p/6702019.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!