python正则表达式 如何找到指定字符后面完整的数字字符串
源串:s='ID:042SEX:MDOB:1967-08-17Status:Active1968'p=re.compile(r'(19|20)\d{2}')s='ID:0...
源串: s = 'ID: 042 SEX: M DOB: 1967-08-17 Status: Active 1968'
p = re.compile(r'(19|20)\d{2}')
s = 'ID: 042 SEX: M DOB: 1967-08-17 Status: Active 1968'
print p.search(s).group()
print p.findall(s)
我想找到19或20开头的, 后面捡完整的2位数字, 如 上面的表达式,
当调用 search的时候, 我希望输出 1967和1968, 而 p.findall我希望输出['1967','1968'] 展开
p = re.compile(r'(19|20)\d{2}')
s = 'ID: 042 SEX: M DOB: 1967-08-17 Status: Active 1968'
print p.search(s).group()
print p.findall(s)
我想找到19或20开头的, 后面捡完整的2位数字, 如 上面的表达式,
当调用 search的时候, 我希望输出 1967和1968, 而 p.findall我希望输出['1967','1968'] 展开
展开全部
1. 首先 p.search(s) 只会找第一个匹配的字符串
2. 其次 p.findall(s) 会记录匹配的组,而(19|20) 代表一个组,应该改成(?:19|20)
以下代码可以满足你的要求:
# -*- coding: utf-8 -*-
from __future__ import print_function, division
import re
s = 'ID: 042 SEX: M DOB: 1967-08-17 Status: Active 1968'
p = re.compile(r'(?:19|20)\d{2}')
#s = 'ID: 042 SEX: M DOB: 1967-08-17 Status: Active 1968'
all_items = re.findall(p,s)
map(print, all_items)
print(all_items)
2. 其次 p.findall(s) 会记录匹配的组,而(19|20) 代表一个组,应该改成(?:19|20)
以下代码可以满足你的要求:
# -*- coding: utf-8 -*-
from __future__ import print_function, division
import re
s = 'ID: 042 SEX: M DOB: 1967-08-17 Status: Active 1968'
p = re.compile(r'(?:19|20)\d{2}')
#s = 'ID: 042 SEX: M DOB: 1967-08-17 Status: Active 1968'
all_items = re.findall(p,s)
map(print, all_items)
print(all_items)
追问
没有再简单点的方式了么? 比如用一条语句 search或match搞定 多谢
追答
...这已经很简单了..。你追求代码量少?
# -*- coding: utf-8 -*-
import re
s = 'ID: 042 SEX: M DOB: 1967-08-17 Status: Active 1968'
p = re.compile(r'(?:19|20)\d{2}')
print " ".join(re.findall(p,s))
print re.findall(p,s)
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询