import re
teststr = "wwcdcaon111sdsda\nw\ncwckjkkkk\npppphellowordcc!"
# (1)'.'匹配\n(换行符)以外的任何字符
pattern = re.compile(r'w.c')
print pattern.findall(teststr)
# (2)'*'前面字符出现0次以及以上
pattern = re.compile(r'w*c')
print pattern.findall(teststr)
# (3)'.*'除\n以外任意字符出现0次以及以上,贪婪,开始到结束所有符合规则的所有内容
pattern = re.compile(r'w.*c')
print pattern.findall(teststr)
# (4)'.*?'除\n以外任意字符出现0次以及以上,非贪婪,截取开始到结束第一个符合规则的内容
pattern = re.compile(r'w.*?c')
print pattern.findall(teststr)
# (5)'(.*?)'匹配内容同(4),但是输出只保留括号中内容
pattern = re.compile(r'w(.*?)c')
print pattern.findall(teststr)
# (6)在(5)的匹配结果下,re.S不会对\n进行中断
# re.S 即为 . 并且包括换行符在内的任意字符(. 不包括换行符)
pattern = r'w(.*?)c'
print re.findall(pattern, teststr, re.S)
结果示例:
['wwc']
['wwc', 'c', 'c', 'wc', 'c', 'c']
['wwcdc', 'wc', 'wordcc']
['wwc', 'wc', 'wordc']
['w', '', 'ord']
['w', '\n', '', 'ord']