Chinaunix

标题: 求助帮忙 [打印本页]

作者: tonkie    时间: 2017-03-03 14:29
标题: 求助帮忙
请大家帮忙,先谢了!
我想实现这样的功能:  在文本中有很多段如,以Starting行开头, exit行开头结尾的段,Starting 到exit中间的数据不一样,还有其他不一样开头的数据。

比如文本内容:

Starting (AXX BXX CXXX DXX EXX FXX HXX GXX IXX)
2017/03/02 17:37:16 ** Error: Unable to determine server for project 'test'.
2017/03/02 17:37:16 ** Error: Unable to determine server for project 'test'.
2017/03/02 17:37:16 ** Error: Unable to determine server for project 'test'.
2017/03/02 17:37:16 ** Error: Unable to determine server for project 'test'.

2017/03/02 17:37:16 ** Error: Unable to determine server for project 'test'.
2017/03/02 17:37:16 ** Error: Unable to determine server for project 'test'.
2017/03/02 17:37:16 ** Error: Unable to determine server for project 'test'.
2017/03/02 17:37:16 ** Error: Unable to determine server for project 'test'.

exit status=0

License Option: ident

Starting (AXX BXX CXXX DXX EXX FXX HXX GXX IXX)
2017/03/02 17:37:16 ** Error: Unable to determine server for project 'test'.
2017/03/02 17:37:16 ** Error: Unable to determine server for project 'test'.


exit status=0

The message returned from the system is: libgd_sh.so: cannot open shared object file: No such file or directory


Starting (AXX BXX CXXX DXX EXX FXX HXX GXX IXX)
2017/03/02 17:37:16 ** Error: Unable to determine server for project 'test'.
2017/03/02 17:37:16 ** Error: Unable to determine server for project 'test'.
2017/03/02 17:37:16 ** Error: Unable to determine server for project 'test'.
2017/03/02 17:37:16 ** Error: Unable to determine server for project 'test'.


exit status=0

\# Available memory:          5,606 MB at UTC 2017.03.02 09:38:48.800
\# Memory report: Maximum memory size now 5,847 MB at UTC 2017.03.02 09:38:48.800
\# Thread usage report: 3 active threads, active load 1.00 at UTC 2017.03.02 09:38:48.800
\o
\# Memory report: on exit            242 MB, process size 1,161 MB at UTC 2017.03.02 09:38:48.809
\# Memory report: peak usage         242 MB, process size 1,161 MB



怎么用正则表示式实现: 把Starting 到 exit所有段的内容抓出来?

作者: moperyblue    时间: 2017-03-03 15:10

  1. awk '/^Starting/{f=1}f;/^exit/{f=0}' urfile
复制代码

作者: tonkie    时间: 2017-03-03 15:20
回复 2# moperyblue

多谢!达到目的了,能否解释下f=1 f=0是什么功能?
非常感谢!

作者: sunzhiguolu    时间: 2017-03-03 16:30
  1. s/(?<=exit\sstatus=0\n)((?!Starting).*\n)*//g
复制代码

作者: moperyblue    时间: 2017-03-03 16:31
回复 3# tonkie


一个用于标识的变量 在区间开始(Starting)的时候开启 在区间结束(exit)的时候关闭
作者: moperyblue    时间: 2017-03-03 16:37

  1. grep -oPz '^(Starting.*\n)(.*\n)*?exit.*' urfile
复制代码





欢迎光临 Chinaunix (http://bbs.chinaunix.net/) Powered by Discuz! X3.2