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

Unix/Linux
linux 操作技巧收集_
linux下如何读取使用iso 镜像文件的方法
Linux平台下文件的压缩与解压参数说明
Linux下常用压缩格式的压缩与解压方法
Linux JDK,TOMCAT安装及环境设置
Linux sleep命令使用参数
Linux cat命令参数
nfs 配置的简单例子
linux kill 关闭进程命令
linux ultrasphinx Anonymous modules have no name to be referenced by
Linux oracle 9i图文安装方法一
Linux oracle 9i图文安装教程二
Linux oracle 9i图文安装教程三
Linux oracle 9i图文安装教程四
Linux oracle 9i图文安装教程五
Linux oracle 9i图文安装教程六 完结篇
linux AS3 oracle9i 安装指南
Linux 下 (RedHat 9.0) JDK,Tomcat,MySQL的安装
RedHat 9.0下Apache+PHP+MySQL服务器安装配置
Linux 下用 Python 连接 MSSql Server 2008

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


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-11-01   浏览: 61 ::
收藏到网摘: 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