作者:无敌小志哥_443 | 来源:互联网 | 2023-09-15 15:27
re.match() 总是从字符串“开头”去匹配,并返回匹配的字符串的match对象。所以当我用re.match()函数去匹配字符串非开头部分的字符串时,会返回NONE。
- str1 = 'Hello World!'
- print(re.match(r'e',str1))
结果为:NONE 如果想查找字符串任意部分的模式出现位置请用re.search()或re.findall().
re.search()函数将对整个字符串进行搜索,并返回第一个匹配的字符串的match对象。
"code"
class="python">str1 = 'Hello World!'
print(re.search(r&#39;e&#39;,str1))输出结果: <_sre.SRE_Match object; span=(1, 2), match=&#39;e&#39;>
re.findall()函数将返回一个所有匹配的字符串的字符串列表。
- str1 = &#39;Hello World!&#39;
- re.findall(r&#39;e&#39;,str1)
输出结果将是: [&#39;e&#39;]
如果你想以迭代方式返回匹配,可以使用 finditer() 方法来代替。
1.TypeError: cannot use a string pattern on a bytes-like object 这种情况解决方法就是加上html=html.decode(&#39;utf-8&#39;)#python3这句代码