我想提取不包含#的行并删除输出中的“,;”.
我的输入FILE如下所示:
# ;string"1" # string"2"; string"3";
可以使用grep和tr来获得想要的输出:
grep -v '#' FILE | tr -d ';"' string3
但是我想用awk.
我可以提取反转匹配awk’!/#/’FILE,但是如何使用sub来删除“,”;在同一个awk命令中?
解决方法
您可以使用gsub进行全局替换:
awk '!/#/{gsub(/[";]/,"",$0);print}'
以下脚本显示了这一点,它提供了与grep / tr管道相同的结果:
pax> echo '# ;string"1" # string"2"; string"3";' | awk '!/#/{gsub(/[";]/,$0);print}{}' string3
请注意,在awk的某些实现中,最终的{}可能不是必需的,但它会在那些实现(通常是较旧的)中停止输出非匹配行,这些行自动执行以匹配任何规则的行.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。