1.使用“\d+”匹配全数字
代码:
1 import re 2 3 zen = "Arizona 479, 501, 870. Carlifornia 209, 213, 650." 4 5 m = re.findall("\d+", zen) 6 7 print(m)
结果:
['479', '501', '870', '209', '213', '650']
但是上述这种方式也会引入非纯数据,例子如下:
1 import re 2 3 zen = "Arizona 479, 501, 870. Carlifornia 209, 213, 650. string666xxx." 4 5 m = re.findall("\d+", zen) 6 7 print(m)
结果:
['479', '501', '870', '209', '213', '650', '666']
2.使用r“\b\d+\b”匹配纯数字数据(r表示原生字符,具有转义作用)
代码:
1 import re 2 3 zen = "Arizona 479, 501, 870. Carlifornia 209, 213, 650. string666xxx." 4 5 m = re.findall(r"\b\d+\b", zen) 6 7 print(m)
结果:
['479', '501', '870', '209', '213', '650']
第一种情况表达式开头有没有 r 影响不大,第二种情况只有加了 r 才能使用\b(代表前后均有空格的纯数字), 否则只会返回一个空列表
来源:https://www.cnblogs.com/Anber82/p/12193364.html