在 awk 中使用多个分隔符 [英] Using multiple delimiters in awk
本文介绍了在 awk 中使用多个分隔符的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我有一个包含以下几行的文件:
I have a file which contain following lines:
/logs/tc0001/tomcat/tomcat7.1/conf/catalina.properties:app.env.server.name = demo.example.com
/logs/tc0001/tomcat/tomcat7.2/conf/catalina.properties:app.env.server.name = quest.example.com
/logs/tc0001/tomcat/tomcat7.5/conf/catalina.properties:app.env.server.name = www.example.com
在上面的输出中,我想提取 3 个字段(数字 2、4 和最后一个 *.example.com
).我得到以下输出:
In above output I want to extract 3 fields (Number 2, 4 and the last one *.example.com
). I am getting the following output:
cat file | awk -F'/' '{print $3 " " $5}'
tc0001 tomcat7.1
tc0001 tomcat7.2
tc0001 tomcat7.5
如何提取'='
之后的域名的最后一个字段?如何使用 multiple delimiter
提取字段?
How do I also extract last field with domain name which is after '='
? How do I use multiple delimiter
to extract field?
推荐答案
分隔符可以是正则表达式.
The delimiter can be a regular expression.
awk -F'[/=]' '{print $3 " " $5 " " $8}' file
产生:
tc0001 tomcat7.1 demo.example.com
tc0001 tomcat7.2 quest.example.com
tc0001 tomcat7.5 www.example.com
这篇关于在 awk 中使用多个分隔符的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文