import re
#match用法
pattern=re.compile(r'hello')
match=pattern.match('hello world')
if match:
print match.group()
else:
print 'sorry'
#split用法,正則匹配分割
p=re.compile(r'\d+')
s=p.split('0one1two2three3four4')
s2=for line in s:
if line=='':
del line
continue
else:
print s2
print re.split(r'\d+','0one1two2three3four4')
#findall用法,正則匹配查
a=['0one1two2three3four4']
print(a)
p_findall=re.compile(r'\d+')
print p_findall.findall('0one1two2three3four4')
for aa in a:
print re.findall(r'\d+',aa)
#sub用法,正則匹配查詢替換
str='the100 god102 is a dog'
rep=re.sub('god','cat',str,flags=0)
print rep
a='kkk111<11110>111<0000>kkk(456412)fdfdf'
s=re.compile(r'.*?<(.*?)>.*<(.*?)>.*\((.*?)\).*?',re.s)
ss=re.findall(s,a)
for line in ss:
print line
b='水費 0.00 -- 0.00 0.00噸 1.68元/噸 0.00 本體維修金:100.00 安全費:0.00 應交租金:4,000.50 應交押金:4,000.03 總金額: 8,100.53'
s1=re.compile(r'.*?應交租金:(.*?) .*',re.s)
ss1=re.findall(s1,b)
print re.findall(r'.*?應交租金:(.*?) .*',b)
正規表示式 正規表示式 總結
非負整數 d 正整數 0 9 1 9 0 9 非正整數 d 0 負整數 0 9 1 9 0 9 整數 d 非負浮點數 d d 正浮點數 0 9 0 9 1 9 0 9 0 9 1 9 0 9 0 9 0 9 1 9 0 9 非正浮點數 d d 0 0 負浮點數 正浮點數正則式 英文本串 a za z...
正規表示式 表示式
網域名稱 a za z0 9 a za z0 9 a za z0 9 a za z0 9 interneturl a za z s 或 http w w w 手機號碼 13 0 9 14 5 7 15 0 1 2 3 5 6 7 8 9 18 0 1 2 3 5 6 7 8 9 d 號碼 x x x...
Linux正規表示式 編寫正規表示式
為了所有實用化的用途,你可以通過使用程式產生正確的結果。然而,並不意味著程式總是如你所願的那樣正確地工作。多數情況下,如果程式不能產生想要的輸出,可以斷定真正的問題 排除輸入或語法錯誤 在於如何描述想要的東西。換句話說,應該考慮糾正問題的地方是描述想要的結果的表示式。表示式不完整或者公式表示得不正確...