当前位置: 首页 > 图文教程 > 操作系统 > Unix/Linux > shell问答1:从文件中抽取字段

Unix/Linux
linux内核编译详解
在linux下面叫firefox 支持java (zt)
利用tar包安装和配置高可用性的vsftp(转)
如何安装.src.rpm软件包:
uClinux操作系统移植,看看
Big Endian and Little Endian
关于ARM处理器Remap的理解 (抄的)
基于S3C4510B的系统的Flash擦除与烧写问题(一)
基于S3C4510B的系统的Flash擦除与烧写问题(二)
Linux指令篇:讯息传送与信件管理--mesg
Linux指令篇:讯息传送与信件管理--mailq
Linux指令篇:讯息传送与信件管理--mail
Linux指令篇:讯息传送与信件管理--aliases
Linux指令篇:使用者资讯与管理--chsh
Linux指令篇:使用者资讯与管理--chfn
Linux指令篇:起始管理--init
Linux指令篇:起始管理--halt
Linux指令篇:使用者管理--su
Linux网管123---第4章.安装及硬体组态-6.硬体组态
Linux指令篇:DOS相容指令--mcd

Unix/Linux 中的 shell问答1:从文件中抽取字段


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-11-01   浏览: 70 ::
收藏到网摘: n/a

有一个文件,如下,以空格分成3段(每段是7行),我现在想这样从里面抽取数据,如果某段中含有字段“REPORT COUNT= 22985”(如果含有的话,肯定是在这段的第6行中含有),则把这一段数据都放到一个新文件中,该如何实现呢?
有一个文件,如下,以空格分成3段(每段是7行),我现在想这样从里面抽取数据,如果某段中含有字段“REPORT COUNT= 22985”(如果含有的话,肯定是在这段的第6行中含有),则把这一段数据都放到一个新文件中,该如何实现呢?? 代码:YTCMSC01 AMA112 MAR07 15:19:01 2900 INFO LONG DURATION CALL ORIG= CDMA_CPS 000000 TERM= CLG NO= 13355356234 CLD NO= $ CONNECT TIME= 066/1426170 REPORT COUNT= 22986 ANSWERED= Y YTCMSC01 AMA112 MAR07 15:19:01 2800 INFO LONG DURATION CALL ORIG= CKT YTIGW1TRKE 477 TERM= CKT SB0014VOICE 121 CLG NO= 13854829695 CLD NO= 13361321136 CONNECT TIME= 066/1435147 REPORT COUNT= 22985 ANSWERED= Y YTCMSC01 AMA112 MAR07 15:19:01 2700 INFO LONG DURATION CALL ORIG= CDMA_CPS 000000 TERM= CLG NO= 13356916813 CLD NO= $ CONNECT TIME= 066/0849074 REPORT COUNT= 22984 ANSWERED= Y
解决办法:1.grep 'REPORT COUNT= 22985' -B5 -C1 youfile >newfile2.cat $scr_file|awk 'BEGIN~/REPORT COUNT= 22985/ &print >'$dest_file'}'3.awk 'BEGIN/REPORT COUNT= 22985/{print >"newfile"}' file4.awk ' { for (i=7;i>0;i--);a[1]=;if (a[2]~/REPORT COUNT= 22986/){for (i=7;i>0;i--){print a[i]}}}' yourfile >newfile