免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2749 | 回复: 3

re获取每个值 [复制链接]

论坛徽章:
0
发表于 2018-03-12 10:59 |显示全部楼层
本帖最后由 龙城狂霸小屌丝 于 2018-03-12 11:02 编辑

Active connections: 760
server accepts handled requests request_time
5006365693 5006365693 6791022492 116870885316
Reading: 0 Writing: 14 Waiting: 746


求最后生成KV形式
比如
Active connections: 760
tengine_accepts:5006365693
tengine_handled:5006365693
tengine_requests:6791022492
request_time:116870885316

求大神们指点下 想不出来这些正则该怎么写

论坛徽章:
30
申猴
日期:2014-04-10 09:43:532015年亚洲杯纪念徽章
日期:2015-03-20 14:40:232015亚冠之阿尔纳斯尔
日期:2015-06-02 18:59:042015亚冠之阿尔希拉尔
日期:2015-06-30 15:22:572015亚冠之大阪钢巴
日期:2015-07-20 10:44:332015亚冠之阿尔纳斯尔
日期:2015-10-28 14:57:5215-16赛季CBA联赛之新疆
日期:2015-12-25 10:18:45黑曼巴
日期:2016-06-26 21:39:5315-16赛季CBA联赛之山西
日期:2016-07-25 21:54:2715-16赛季CBA联赛之北京
日期:2016-10-27 12:07:2315-16赛季CBA联赛之八一
日期:2017-07-07 16:39:0915-16赛季CBA联赛之吉林
日期:2017-09-04 12:14:43
发表于 2018-03-13 11:07 |显示全部楼层
回复 1# 龙城狂霸小屌丝
举例不够全面,只能就题论题,py3

import re
with open('file.txt') as f:
        for i in f:
                if re.match(r'^Active',i):
                        print (i,end='')
                elif re.match(r'^server',i):
                        l=i.strip('\n').split(' ')[1:]
                elif re.match(r'\d+',i):
                        for a,b in zip(l,i.split(' ')):
                                print (a+":"+b)


论坛徽章:
11
2015年迎新春徽章
日期:2015-03-04 09:55:282017金鸡报晓
日期:2017-02-08 10:39:4215-16赛季CBA联赛之辽宁
日期:2016-12-15 10:24:1715-16赛季CBA联赛之佛山
日期:2016-11-30 09:04:2015-16赛季CBA联赛之江苏
日期:2016-04-29 15:56:1215-16赛季CBA联赛之同曦
日期:2016-04-12 13:21:182016猴年福章徽章
日期:2016-02-18 15:30:3415-16赛季CBA联赛之山东
日期:2016-02-16 11:37:52每日论坛发贴之星
日期:2016-02-07 06:20:00程序设计版块每日发帖之星
日期:2016-02-07 06:20:0015-16赛季CBA联赛之新疆
日期:2018-01-09 16:25:37
发表于 2018-03-14 13:21 |显示全部楼层
本帖最后由 bskay 于 2018-03-14 13:24 编辑

#首先,分析数据格式:
s='''
Active connections: 760
server accepts handled requests request_time
5006365693 5006365693 6791022492 116870885316
Reading: 0 Writing: 14 Waiting: 746
'''
# 这样,人工自然的按行,按字段划分
text =[
['Active', 'connections:', '760'],
['server', 'accepts', 'handled', 'requests', 'request_time'],
['5006365693', '5006365693', '6791022492', '116870885316'],
['Reading:', '0', 'Writing:', '14', 'Waiting:', '746 '],
]

# 然后把上面需要的数据字段单个替换

text =[
['Active', 'connections:', '(?P<connections>\d+)'],
['server', 'accepts', 'handled', 'requests', 'request_time'],
['(?P<tengine_requests>\d+)', '(?P<tengine_accepts>\d+)', '(?P<tengine_handled>\d+)', '(?P<request_time>\d+)'],
['Reading:', '\d+', 'Writing:', '\d+', 'Waiting:', '\d+'],
]

#然后用 '\s*'连接行,'\s+'连接字段,进行 匹配
re.match('\s*'.join(['\s+'.join(l) for l in text]), s).groupdict()

#如果有多个,用
re.findall('\s*'.join(['\s+'.join(l) for l in text]), s)

论坛徽章:
11
2015年迎新春徽章
日期:2015-03-04 09:55:282017金鸡报晓
日期:2017-02-08 10:39:4215-16赛季CBA联赛之辽宁
日期:2016-12-15 10:24:1715-16赛季CBA联赛之佛山
日期:2016-11-30 09:04:2015-16赛季CBA联赛之江苏
日期:2016-04-29 15:56:1215-16赛季CBA联赛之同曦
日期:2016-04-12 13:21:182016猴年福章徽章
日期:2016-02-18 15:30:3415-16赛季CBA联赛之山东
日期:2016-02-16 11:37:52每日论坛发贴之星
日期:2016-02-07 06:20:00程序设计版块每日发帖之星
日期:2016-02-07 06:20:0015-16赛季CBA联赛之新疆
日期:2018-01-09 16:25:37
发表于 2018-03-14 13:23 |显示全部楼层
结果
>>> re.match('\s*'.join(['\s+'.join(l) for l in text]), s).groupdict()
{'connections': '760', 'tengine_accepts': '5006365693', 'request_time': '116870885316', 'tengine_handled': '6791022492', 'tengine_requests': '5006365693'}
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP