报错发生的情景介绍: 我要筛选出biao1.csv和biao2.csv的不同项,并把不同的内容输出到另外一个文件中;
[root@localhost data]# grep -vwf biao1.csv biao2.csv < ./diff.csv
grep: Invalid range end
最开始我以为是命令用错了,于是把biao1.csv和biao2.csv这两个文件的位置在命令行中对调了一下,但情况还是一样,均出现如上‘grep: Invalid range end’报错。
最后,发现是因为grep命令后面比较的两个文件太大了,如果文件小的话,可以还是可以用grep命令的。但是,如果文件大的话建议用awk命令,反正我这里做比较的文件大小为19M都不行。
如下是用awk命令解决此问题的,命令如下:
awk 'NR==FNR{a[$0]}NR>FNR{ if(!($1 in a)) print $0}' biao1.csv biao2.csv < ./diff.csv
此命令会找出文件 biao1与biao2中不同的值 ,其中 biao2是参考值;