免费注册 查看新帖 |

Chinaunix

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

[文本处理] 帮忙处理一下数据,多谢了。 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-12-04 21:25 |只看该作者 |倒序浏览
现在的格式:
report for localhost (192.168.11.16
details: Linux 2.6.32 - 3.9
report for localhost (192.168.11.15
report for localhost (192.168.11.160)
report for localhost (192.168.11.161)
details: Linux 2.6.32 - 3.9
report for localhost (192.168.11.163)
details: Windows XP

处理为:
192.168.11.168 Linux 2.6.32 - 3.9
192.168.11.158  
192.168.11.160
192.168.11.161 Linux 2.6.32 - 3.9
192.168.11.163 Windows XP

非常感谢了。

论坛徽章:
2
射手座
日期:2014-10-10 15:59:4715-16赛季CBA联赛之上海
日期:2016-03-03 10:27:14
2 [报告]
发表于 2013-12-04 21:38 |只看该作者
本帖最后由 yinyuemi 于 2013-12-05 09:13 编辑

awk '/report/{printf (NR==1?"":RS) gensub("[()]","","g",$NF);next}{$1="";printf $0 }'  file
awk -vRS='report[^\n]+[(]' -F'[)\n]' 'NF{sub("details: ","");$1=$1;print}'

论坛徽章:
60
20周年集字徽章-20	
日期:2020-10-28 14:04:3015-16赛季CBA联赛之北京
日期:2016-07-06 15:42:0715-16赛季CBA联赛之同曦
日期:2016-06-12 10:38:0915-16赛季CBA联赛之佛山
日期:2016-05-27 11:54:56黄金圣斗士
日期:2015-12-02 11:44:35白银圣斗士
日期:2015-11-25 14:32:43白银圣斗士
日期:2015-11-23 12:53:352015亚冠之布里斯班狮吼
日期:2015-10-21 16:55:482015亚冠之首尔
日期:2015-09-01 16:46:052015亚冠之德黑兰石油
日期:2015-08-31 11:39:192015亚冠之萨济拖拉机
日期:2015-08-28 21:06:5315-16赛季CBA联赛之广东
日期:2016-07-12 14:58:53
3 [报告]
发表于 2013-12-04 21:50 |只看该作者
本帖最后由 reyleon 于 2013-12-04 21:51 编辑
  1. grep -Po '(?<=\050).*(?=\051)|(?<=details: ).*' file | sed 'N;/\n[A-Za-z]\+/s/\n/ /;P;D'  
复制代码

论坛徽章:
32
处女座
日期:2013-11-20 23:41:20双子座
日期:2014-06-11 17:20:43戌狗
日期:2014-06-16 11:05:00处女座
日期:2014-07-22 17:30:47狮子座
日期:2014-07-28 15:38:17金牛座
日期:2014-08-05 16:34:01亥猪
日期:2014-08-18 13:34:25白羊座
日期:2014-09-02 15:03:55金牛座
日期:2014-11-10 10:23:58处女座
日期:2014-12-02 09:17:52程序设计版块每日发帖之星
日期:2015-06-16 22:20:002015亚冠之塔什干火车头
日期:2015-06-20 23:28:22
4 [报告]
发表于 2013-12-04 21:52 |只看该作者
  1. [root@localhost ~]# awk '/^details:/{$1="";s=s""$0;next}{gsub(/[()]/,"");s=s?s"\n"$NF:$NF}END{print s}' i
  2. 192.168.11.168 Linux 2.6.32 - 3.9
  3. 192.168.11.158
  4. 192.168.11.160
  5. 192.168.11.161 Linux 2.6.32 - 3.9
  6. 192.168.11.163 Windows XP
  7. [root@localhost ~]#
复制代码

论坛徽章:
32
处女座
日期:2013-11-20 23:41:20双子座
日期:2014-06-11 17:20:43戌狗
日期:2014-06-16 11:05:00处女座
日期:2014-07-22 17:30:47狮子座
日期:2014-07-28 15:38:17金牛座
日期:2014-08-05 16:34:01亥猪
日期:2014-08-18 13:34:25白羊座
日期:2014-09-02 15:03:55金牛座
日期:2014-11-10 10:23:58处女座
日期:2014-12-02 09:17:52程序设计版块每日发帖之星
日期:2015-06-16 22:20:002015亚冠之塔什干火车头
日期:2015-06-20 23:28:22
5 [报告]
发表于 2013-12-04 22:03 |只看该作者
本帖最后由 yestreenstars 于 2013-12-04 22:05 编辑
  1. [root@localhost ~]# sed 's/.*(\|)//g;N;s/\n.*://;P;D' i
  2. 192.168.11.168 Linux 2.6.32 - 3.9
  3. 192.168.11.158
  4. 192.168.11.160
  5. 192.168.11.161 Linux 2.6.32 - 3.9
  6. 192.168.11.163 Windows XP
  7. [root@localhost ~]#
复制代码

论坛徽章:
0
6 [报告]
发表于 2013-12-05 00:23 |只看该作者
回复 5# yestreenstars


   大神、敢不敢写的再简单点

论坛徽章:
7
亥猪
日期:2013-10-10 17:00:29辰龙
日期:2013-10-12 16:23:19卯兔
日期:2013-11-18 17:01:27金牛座
日期:2014-09-09 10:17:052015七夕节徽章
日期:2015-08-21 11:06:172015亚冠之柏太阳神
日期:2015-09-25 13:56:42数据库技术版块每日发帖之星
日期:2016-08-06 06:20:00
7 [报告]
发表于 2013-12-05 09:36 |只看该作者
  1. awk -F"[(:]" '/report/{s=gensub(/)/,"",1,$NF)}{if(/details/)a[s]=$NF;else a[s]=""}END{for(s in a)print s a[s]}'
复制代码

论坛徽章:
145
技术图书徽章
日期:2013-10-01 15:32:13戌狗
日期:2013-10-25 13:31:35金牛座
日期:2013-11-04 16:22:07子鼠
日期:2013-11-18 18:48:57白羊座
日期:2013-11-29 10:09:11狮子座
日期:2013-12-12 09:57:42白羊座
日期:2013-12-24 16:24:46辰龙
日期:2014-01-08 15:26:12技术图书徽章
日期:2014-01-17 13:24:40巳蛇
日期:2014-02-18 14:32:59未羊
日期:2014-02-20 14:12:13白羊座
日期:2014-02-26 12:06:59
8 [报告]
发表于 2013-12-05 10:55 |只看该作者
本帖最后由 jason680 于 2013-12-05 10:55 编辑

回复 1# tstianzy

Would you like this ...

$ $ awk -F'[:()]' 'NF>2{printf("%s",P$2);P="\n"}NF==2{printf $2}END{print""}' FILE
192.168.11.168 Linux 2.6.32 - 3.9
192.168.11.158
192.168.11.160
192.168.11.161 Linux 2.6.32 - 3.9
192.168.11.163 Windows XP

   

论坛徽章:
1
2015年迎新春徽章
日期:2015-03-04 09:58:11
9 [报告]
发表于 2013-12-05 11:00 |只看该作者
回复 8# jason680


   

论坛徽章:
769
金牛座
日期:2014-02-26 17:49:58水瓶座
日期:2014-02-26 18:10:15白羊座
日期:2014-04-15 19:29:52寅虎
日期:2014-04-17 19:43:21酉鸡
日期:2014-04-19 21:24:10子鼠
日期:2014-04-22 13:55:24卯兔
日期:2014-04-22 14:20:58亥猪
日期:2014-04-22 16:13:09狮子座
日期:2014-05-05 22:31:17摩羯座
日期:2014-05-06 10:32:53处女座
日期:2014-05-12 09:23:11子鼠
日期:2014-05-21 18:21:27
10 [报告]
发表于 2013-12-05 14:41 |只看该作者
回复 1# tstianzy
  1. awk '/localhost/{ip=gensub(/.*\((.*)\)/,"\\1",1);s=s?s"\n"ip:ip} /details/{sys=gensub("details: (.*)","\\1",1);s=s" "sys}END{print s}' i
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP