如何解决使用累加器使用bash逐行比较具有多列的两个文件
我有两个文件:
文件1:
a b 30 d
a b 50 d
和file2:
a b 20 d
a b 60 d
首选输出文件file_output:
a b 20 d
a b 50 d
我想逐行比较每个文件,并想在输出文件中打印,其中使用awk在第三列中的数字较小的那一行。
我尝试过类似的事情:
awk ' NR==FNR { arr[$3];next} arr[$3] < $3 ' file1 file2 > file_output
但是它只为file1打印较小的文件,而不为file2打印
解决方法
awk 'FNR==NR {f3[FNR]=$3;a[FNR]=$0;next} FNR in a {print ($3<f3[FNR])?$0:a[FNR]}' file1 file2
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。