繁体   English   中英

使用sed从字符串中提取子字符串

[英]Extract substring from string with sed

我想从snmpwalk输出中提取MIB对象。 输出FILE如下所示:

RFC1213-MIB::sysDescr.0.0.0.0.192.168.1.2 = STRING: "Linux debian 3.16.0-4-amd64 #1 SMP Debian 3.16.43-2+deb8u1 (2017-06-18) x86_64"
RFC1213-MIB::sysObjectID.0 = OID: RFC1155-SMI::enterprises.8072.3.2.10
..

首先,我读取输出文件,将其分割为character =并删除RFC1213-MIB::.0之间的所有内容,直到字符串结尾。

while read -r; do echo "${REPLY%%=*}" | sed -e 's/RFC1213-MIB::\(.*\)\.0/\1/'; done <$FILE

我当前的输出:

sysDescr.0.0.0.192.168.1.2 
sysObjectID

如何删除其他值? 有更好的解决方案,提取sysDescrsysObjectID吗?

使用awk:

awk -F[:.] '{print $3}'

(将:.定义为字段分隔符,并显示第三个字段)

与sed(Gnu):

sed 's/^[^:]*::\|\.0.*//g'

(用空字符串替换所有这不是一个:接着::在该行或第一开始.0和以下字符到行的结尾)

也许您可以尝试:

sed 's/RFC1213-MIB::\([^\.]*\).*/\1/' $FILE

这将得到RFC1213-MIB::字符串后不是点( . )的所有内容。

如果您不想使用sed,则可以使用参数替换。 sed是一个外部过程,因此它不像参数替换那样快,因为它是内置的bash。

while IFS= read -r line; do line=${line#*::}; line=${line%%.*}; echo $line; done < file

line=${line#*::}假定RFC1213-MIB没有两个冒号,并且将从sysDescr拆分为两个冒号。

line=${line%%.*}假设sysDescr会有一个. 之后。

如果您有更多示例,认为您无法使用,我可以更新答案。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM