Unix命令在一个文件中查找行,而在另一个文件中找不到该键

问题描述 投票:-1回答:1

两个文件都已排序并重复删除。我想将file1中的field1与file2的field1进行比较,并输出file2中不在file2中的行。 field1没有设置长度,这导致我使用uniq时遇到问题。

这是一个数据示例:

菲尔1:

UUID(78-d55) NODETYPE(B) 22:42:05  
UUID(78-d51) NODETYPE(B) 22:42:05
UUID(78-dca) NODETYPE(B) 22:42:37
UUID(78-494) NODETYPE(B) 22:42:37
UUID(dp@20181206003956969) NODETYPE(B)  00:39:56

文件2:

UUID(78-d55) NODETYPE(B) POLNODE(/inbound/us)   
UUID(78-74e) NODETYPE(B) POLNODE(/inbound/us) 
UUID(78-053) NODETYPE(B) POLNODE(/inbound/us)     
UUID(78-5d6) NODETYPE(B) POLNODE(/inbound/us)    
UUID(78-dca) NODETYPE(B) POLNODE(/inbound/us)   
UUID(78-b0b) NODETYPE(B) POLNODE(/inbound/us)    
UUID(dp@20181206003956969) NODETYPE(B)  POLNODE(/inbound/us) 

我想要的是:

UUID(78-d51) NODETYPE(B) 22:42:05 
UUID(78-494) NODETYPE(B) 22:42:37 
unix filecompare
1个回答
1
投票

看起来像join的工作 - 及其-v选项:

$ join -v1 file1 file2
UUID(78-d51) NODETYPE(B) 22:42:05
UUID(78-494) NODETYPE(B) 22:42:37
$

请注意,这取决于正在排序的文件(如上所述),以及每个文件中第1列的连接列以及由空格或制表符分隔的字段。如有必要,可以通过额外选项改变其中的每一个。

它也可以在Awk中轻松完成 - 以及Perl和Python以及其他可编写脚本的语言。

© www.soinside.com 2019 - 2024. All rights reserved.