我想
提取不包含#的行并
删除输出中的“,;”.
@H_
502_2@我的输入FILE如下所示:
# ;string"1"
# string"2";
string"3";
@H_
502_2@可以使用grep和tr来获得想要的
输出:
grep -v '#' FILE | tr -d ';"'
string3
@H_
502_2@但是我想用awk.
@H_
502_2@我可以
提取反转匹配awk’!/#/’FILE,但是如何使用sub来
删除“,”;在同一个awk命令中?
您可以使用gsub进行全局替换:
awk '!/#/{gsub(/[";]/,"",$0);print}'
@H_
502_2@以下脚本
显示了这一点,它提供了与grep / tr管道相同的结果:
pax> echo '# ;string"1"
# string"2";
string"3";' | awk '!/#/{gsub(/[";]/,$0);print}{}'
string3
@H_
502_2@请注意,在awk的某些实现中,最终的{}可能不是必需的,但它会在那些实现(通常是较旧的)中停止
输出非匹配行,这些行
自动执行以匹配任何规则的行.