1.使用“\d+”匹配全数字
代码:
1
2
3
4
|
import re
zen = "Arizona 479, 501, 870. Carlifornia 209, 213, 650."
m = re.findall( "\d+" , zen)
print (m)
|
结果:
['479', '501', '870', '209', '213', '650']
但是上述这种方式也会引入非纯数据,例子如下:
1
2
3
4
|
import re
zen = "Arizona 479, 501, 870. Carlifornia 209, 213, 650. string666xxx."
m = re.findall( "\d+" , zen)
print (m)
|
结果:
['479', '501', '870', '209', '213', '650', '666']
2.使用r“\b\d+\b”匹配纯数字数据(r表示原生字符,具有转义作用)
代码:
1
2
3
4
|
import re
zen = "Arizona 479, 501, 870. Carlifornia 209, 213, 650. string666xxx."
m = re.findall(r "\b\d+\b" , zen)
print (m)
|
结果:
['479', '501', '870', '209', '213', '650']
第一种情况表达式开头有没有 r 影响不大,第二种情况只有加了 r 才能使用\b(代表前后均有空格的纯数字), 否则只会返回一个空列表
总结
以上所述是小编给大家介绍的Python正则表达式匹配字符串中的数字,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对服务器之家网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
原文链接:https://www.cnblogs.com/Anber82/archive/2020/01/14/12193364.html