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(代表前后均有空格的纯数字), 否则只会返回一个空列表

SRE实战 互联网时代守护先锋,助力企业售后服务体系运筹帷幄!一键直达领取阿里云限量特价优惠。
扫码关注我们
微信号:SRE实战
拒绝背锅 运筹帷幄