我有以下字符串:
1360308597服务通知: qreda;demo-jms2;OutConnectorResponse;notify-service-by-email;CRITICAL ConsumerCount=01360308817服务通知:qreda;演示-jms2 2;磁盘空间;关键;通过电子邮件通知-服务;磁盘关键空闲空间: /data 3018 MB (10% inode=92%):
在上面的字符串中,我想提取demo-jms2后面的字符串。在这里,demo-jms2发生两次。我想得到demo-jms2后面的所有单词,所以答案应该是OutConnectorResponse和Disk Space。
发布于 2013-02-08 09:33:46
你想要的是积极后视
$ grep -Po '(?<=demo-jms2;)[^;]+' file
OutConnectorResponse
Disk Space选项:
-P,- Perl -regexp模式是Perl正则表达式。 -o,-只显示匹配模式的一部分。
解释:
(?<=demo-jms2;) # Positive lookbehind: match the follow after literal demo-jms2;
[^;]+ # Match one or more non ; characters 编辑:
通过sort -u从结果管道中筛选副本
$ grep -Po '(?<=demo-jms2;)[^;]+' file
OutConnectorResponse
Disk Space
OutConnectorResponse
Disk Space
$ grep -Po '(?<=demo-jms2;)[^;]+' file | sort -u
Disk Space
OutConnectorResponsehttps://stackoverflow.com/questions/14769250
复制相似问题