如何使用Awk比较两个文件的行数



我是awk的新手,需要比较两个文件的行数。脚本应返回true,

if lines(f1) == (lines(f2)+1)

否则为false。我该怎么做?

向致以最良好的问候

如果必须是awk:

awk 'NR==FNR{x++} END{ if(x!=FNR){exit 1} }' file1 file2

变量x递增并包含file1的行数,FNR包含file2的行数。最后,将两者进行比较,并以0或1退出脚本。

参见示例:

user@host:~$ awk 'NR==FNR{x++} END{ if(x!=FNR){exit 1} }' shortfile longfile
user@host:~$ echo $?
1
user@host:~$ awk 'NR==FNR{x++} END{ if(x!=FNR){exit 1} }' samefile samefile
user@host:~$ echo $?
0

这样的东西应该适合您的目的:

 [ oele3110 $] cat line_compare.awk
#!/usr/bin/gawk -f
NR==FNR{
    n_file1++;
}
NR!=FNR{
    n_file2++;
}
END{
    n_file2++;
    if(n_file1==n_file2){exit(1);}
}
 [ oele3110 $] cat f1
1
1
1
1
1
1
 [ oele3110 $] cat f2
1
1
1
1
1
 [ oele3110 $] cat f3
1
1
1
1
1
 [ oele3110 $]
 [ oele3110 $] wc -l f*
 6 f1
 5 f2
 5 f3
16 total
 [ oele3110 $] ./line_compare.awk f1 f2
 [ oele3110 $] echo $?
1
 [ oele3110 $] ./line_compare.awk  f2 f3
 [ oele3110 $] echo $?
0
 [ oele3110 $]

事实上,我想在给你答案之前,我应该让你多花点力气。我暂时不谈,但下次我不会再犯同样的错误了。

相关内容

  • 没有找到相关文章

最新更新