关于python正则表达式中函数findall的用法?

1.我的目标是匹配一个地址 ex:123 xuancheng anhui China
2.我给的正则表达式为:r'd+(s+[a-zA-Z]+)+s*'
代码如下:

pattern = r'\d+(\s+[a-zA-Z]+)+\s*'
basestr = '123  xuancheng china '
m1 = re.findall(pattern, basestr)
if m1 is not None:
    print m1
得到的结果为 [' china']

这个是以圆括号的内容进行匹配的,我想要配置的是整句话,如何改造呢?
除了以下这个用法
pattern_2 = r'(d+(s+[a-zA-Z]+)+s*)'
返回
[('123 xuancheng china ', ' china')]
使用search 函数能得到想要的结果
m2 = re.search(pattern, basestr)
print m2.group()
得到:
123 xuancheng china

阅读 10.2k
2 个回答

r'\d+(?:\s+[a-zA-Z]+)+\s*'

简单粗暴是这样的,请自己再修改。
图片描述

再修改一下是这样的
图片描述

提供的新的字符串也可以。
图片描述

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题