免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1939 | 回复: 6
打印 上一主题 下一主题

[文本处理] 为工作急求大神 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-12-21 11:29 |只看该作者 |倒序浏览
log.txt文件内容如下:

lunch pid with 123
check wifi,found
check BT,found
check Sensor,found
pid 123 successed exit with 0
lunch pid with 124
check wifi,found
check BT,not found
check Sensor,found
pid 124 successed exit with 205
lunch pid with 125
check wifi,found
check BT,found
check Sensor,found
pid 126 successed exit with 0
...........省略了N多行

这是一个很大的测试LOG文本文件(5M)的一部分,总是以lunch pid with xxx开头,以pid xxx successed exit with xxx结束
当测试失败的时候,关键字就是not/NOT found,以及exit with后面的数字不等于零。表征某进程测试失败的关键字:not/NOT found ,exit with不等于0

现在工作的内容就是,把测试失败的找寻出来(从lunch pid with xxx到pid xxx successed exit with xxx的部分调出来写到另一个文件(暂命名为tem.txt吧)中)

接着对上面的temp.txt进行分析,生成如下格式的excel或.csv文件
pid            result code                    reason
124                205                     check BT,not found

论坛徽章:
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
2 [报告]
发表于 2014-12-21 12:02 |只看该作者
本帖最后由 zxy877298415 于 2014-12-21 16:20 编辑
  1. awk 'BEGIN{print "pid\tresultcode\treason" > "temp.txt";RS="lunch";FS="\n"}
  2. NR>1{for (i=1;i<=(NF-1);i++) {if ($i~/(not|NOT) found/) {split($(NF-1),a," ");print a[2]"\t"a[length(a)]"\t\t"$i>>"temp.txt"}} }' log.txt
  3. cat temp.txt
  4. pid     resultcode      reason
  5. 124     205             check BT,not found
复制代码
回复 1# 26号铁神



   

论坛徽章:
3
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:51:162015年亚洲杯之阿曼
日期:2015-04-07 20:00:59
3 [报告]
发表于 2014-12-21 12:06 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
4 [报告]
发表于 2014-12-21 15:48 |只看该作者
非常感谢,但是和我的需求还有点距离,我调试了几次您的脚本。shell真的好伟大,可以减少好多重复性劳动,我也要努力学好。回复 2# zxy877298415


   

论坛徽章:
0
5 [报告]
发表于 2014-12-21 15:50 |只看该作者
谢谢大神您,您的较2楼优化,但是还是需要修改一下下。感谢您以及2楼大神的付出。努力学好shell!回复 3# zooyo


   

论坛徽章:
3
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:51:162015年亚洲杯之阿曼
日期:2015-04-07 20:00:59
6 [报告]
发表于 2014-12-22 00:05 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
46
2015小元宵徽章
日期:2015-03-06 15:58:18羊年新春福章
日期:2015-04-14 10:37:422015年亚洲杯之阿曼
日期:2015-04-14 10:41:50NBA常规赛纪念章
日期:2015-05-04 22:32:03NBA季后赛大富翁
日期:2015-05-04 22:34:11菠菜明灯
日期:2015-05-04 22:35:49新奥尔良黄蜂
日期:2015-05-04 22:49:2315-16赛季CBA联赛之广夏
日期:2015-12-11 15:02:342015年亚洲杯之巴勒斯坦
日期:2015-03-04 19:56:562015年亚洲杯之阿联酋
日期:2015-03-04 11:19:04休斯顿火箭
日期:2015-03-02 16:32:11纽约尼克斯
日期:2015-03-02 16:09:04
7 [报告]
发表于 2014-12-22 10:17 |只看该作者
awk '$1=="lunch"{delete a}{a[NR%6]=$0;if($4=="exit" && $NF!=0){for(i=0;i<5;i++)print a[i]}}'
不知道效率怎么样
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP