我基本上喜欢结合的力量
grep -f
同
awk '{ if($2=="this is where I'd like to input a file of fixed string patterns") print $0}'
也就是说,我想用模式的输入文件(文件2)搜索文件的特定列(文件1).如果找到匹配只是:
> outputfile.txt
awk 'NR==FNR{a[$0]=1;next} {n=0;for(i in a){if($0~i){n=1}}} n' file1 file2
取自Obtain patterns in one file from another using ack or awk or better way than grep?
你找到的例子确实非常接近你想要的,唯一的区别是你不想匹配整行($0).
awk 'NR==FNR { pats[$0]=1; next } { for(p in pats) if($2 ~ p) { print $0; break } }' patterns file
如果您只需要一个固定的字符串匹配,请使用index()函数,即用索引($2,p)替换$2~p.
你也可以提供列号作为awk的参数,例如:
awk -v col=$col 'NR==FNR { pats[$0]=1; next } { for(p in pats) if($col ~ p) { print $0; break } }' patterns file
编辑 – 整个字段匹配
您可以使用==运算符完成此操作:
awk -v col=$col 'NR==FNR { pats[$0]=1; next } { for(p in pats) if($col == p) { print $0; break } }' patterns file
原文地址:https://www.jb51.cc/bash/386970.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。