如何解决使用sed从配置文件中提取某些字符串
我正在尝试从下面的输出中导出某些字符串,但是我没有sed / awk的经验,我需要一些建议以解决该问题。
输入:
name Cleartext-Password := "password",Service-Type := Framed-User
Framed-IP-Address := 127.0.0.1,MS-Primary-DNS-Server := 8.8.8.8,Fall-Through = Yes,Mikrotik-Rate-Limit = 20M/30M
输出应为: 名称;密码; 127.0.0.1; 20M; 30M;
我不确定这是否是正确的方法,但是我尝试删除所需字符串之间的所有内容,例如:
sed 's/ Cleartext-Password := "/;/'
但是我认为这是肮脏的方式,而不是聪明的方式。
您能否让我知道我需要寻找什么才能为此创建有效的sed / awk解决方案?
解决方法
请根据您显示的示例尝试以下操作。在现场编写并测试 https://ideone.com/eWXv3w
由于OP的Input_file具有控制M个字符,因此在此处的代码中添加了 gsub(/\r/,"")
。
awk '
BEGIN{ OFS=";" }
{ gsub(/\r/,"") }
match($0,/Cleartext-Password[^,]*/){
val=substr($0,RSTART,RLENGTH)
gsub(/Cleartext-Password[^"]*|"/,"",val)
val=$1 OFS val
next
}
/Framed-IP-Address/{
sub(/,$/,"")
val=val OFS $NF
next
}
/Mikrotik-Rate-Limit/{
print val,$NF
val=""
}' Input_file
说明: 在程序的BEGIN
的{{1}}部分中,根据问题将OFS
设置为半冒号。然后使用awk的match
函数匹配字符串Cleartext ... Cleartext-Password[^,]*
中的正则表达式,直到出现第一个逗号为止。如果正则表达式完全匹配,则在此处捕获变量val中的该子字符串。现在,根据需要的输出,使用gsub
全局替换Cleartext-Password中的所有内容以及其中所有不必要的内容。
然后检查行是否包含Framed-IP-Address
(如果找到),然后从行尾发送,
并将其最后一个字段添加到变量val。
现在检查条件,如果一行包含Mikrotik-Rate-Limit
,则只需在此处打印val和最后一个字段的值,在此也将val取消。
有多种方法可以使用awk
来解决此问题,关键是将记录的一部分与正则表达式进行匹配,以标识您正在操作的记录,然后将所需的测试和输出隔离到所需的格式。
一种方法是:
awk '
/Cleartext-Password/ { printf "%s;%s;",$1,substr($4,2,length($4)-3) }
/Framed-IP-Address/ { printf "%s;",substr($NF,1,length($NF)-1) }
/Mikrotik-Rate-Limit/{ sub(/\//,";",$NF); printf "%s;\n",$NF }
' config
使用/输出示例
将示例输入到名为config
的文件中,您将收到:
name;password;127.0.0.1;20M;30M;
仔细检查一下,如果我在任何地方误解了,请告诉我。
,这可能对您有用(GNU sed):
sed -nE -e '/Cleartext-Password/{s/ .*:=\s"(.*)",.*/;\1/;h}' \
-e '/Framed-IP-Address/{s/.*:= (.*),/\1/;H}' \
-e '/Mikrotik-Rate-Limit/{s#.*= (.*)/(.*)#\1;\2#;H;g;y/\n/;/;p}' file
通过调用-n
选项关闭隐式打印。
通过调用-E
选项来减少反斜杠。
将记录的字段存储在保留空间中,并在收集完所有字段后,将保留空间复制到模式空间,用字段分隔符替换换行符并打印结果。
您可能更喜欢:
sed -nE '/Cleartext-Password/{s/ .*:=\s"(.*)",.*/;\1/;h};
/Framed-IP-Address/{s/.*:= (.*),/\1/;H};
/Mikrotik-Rate-Limit/{s#.*= (.*)/(.*)#\1;\2#;H;g;y/\n/;/;p}' file
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。