python正則表達式re 中m.group和m.groups的解釋


轉載:http://www.cnblogs.com/kaituorensheng/archive/2012/08/20/2648209.html

先看代碼instance:

 1 >>> a="123abc456"
 2 >>> import re
 3 >>> print(re.search("([0-9]*)([a-z]*)([0-9]*)", a).group(0))
 4 123abc456
 5 >>> print(re.search("([0-9]*)([a-z]*)([0-9]*)", a).group(1))
 6 123
 7 >>> print(re.search("([0-9]*)([a-z]*)([0-9]*)", a).group(2))
 8 abc
 9 >>> print(re.search("([0-9]*)([a-z]*)([0-9]*)", a).group(3))
10 456
11 >>> print(re.search("([0-9]*)([a-z]*)([0-9]*)", a).group())
12 123abc456
13 >>> print(re.search("([0-9]*)([a-z]*)([0-9]*)", a).groups())
14 ('123', 'abc', '456')
15 >>> print(re.search("([0-9])*([a-z])*([0-9]*)", a).groups())
16 ('3', 'c', '456')
17 >>> print(re.search("([0-9])*([a-z])*([0-9]*)", a).groups(1))
18 ('3', 'c', '456')
19 >>> print(re.search("([0-9])*([a-z])*([0-9]*)", a).group(0))
20 123abc456
21 >>> print(re.search("([0-9])*([a-z])*([0-9]*)", a).group())
22 123abc456

究其因:

1. 正則表達式中的三組括號把匹配結果分成三組

  •  m.group() == m.group(0) == 所有匹配的字符(即匹配正則表達式整體結果)
  •  group(1) 列出第一個括號匹配部分,group(2) 列出第二個括號匹配部分,group(3) 列出第三個括號匹配部分。
  • m.groups() 返回所有括號匹配的字符,以tuple格式。m.groups() == (m.group(0), m.group(1), ...)

2. 沒有匹配成功的,re.search()返回None

3. 當然鄭則表達式中沒有括號,group(1)肯定不對了。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM