我有一个python,它的匹配方法总是不返回任何。我在pythex站点上进行了测试,这种模式似乎没有问题。
但是,当我尝试使用re模块时,结果总是没有:
import re
a = re.match(re.compile("\.aspx\?.*cp="), 'page.aspx?cpm=549&cp=168')我做错了什么?
发布于 2014-02-06 13:09:47
re.match()只在字符串的开头匹配。使用re.search()代替:
re.search(r"\.aspx\?.*cp=", 'page.aspx?cpm=549&cp=168')演示:
>>> import re
>>> re.search(r"\.aspx\?.*cp=", 'page.aspx?cpm=549&cp=168')
<_sre.SRE_Match object at 0x105d7e440>
>>> re.search(r"\.aspx\?.*cp=", 'page.aspx?cpm=549&cp=168').group(0)
'.aspx?cpm=549&cp='注意,任何采用模式的re函数,都接受一个字符串,并将为您调用re.compile() (这会缓存编译结果)。如果要存储编译后的表达式以供重用,则只需要使用re.compile(),此时可以在其上调用pattern.search():
pattern = re.compile(r"\.aspx\?.*cp=")
pattern.search('page.aspx?cpm=549&cp=168')https://stackoverflow.com/questions/21603875
复制相似问题