Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/linux/22.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Linux Bash-检查一个文件中的行是否存在于另一个文件中_Linux_Bash_Unix - Fatal编程技术网

Linux Bash-检查一个文件中的行是否存在于另一个文件中

Linux Bash-检查一个文件中的行是否存在于另一个文件中,linux,bash,unix,Linux,Bash,Unix,我想知道如何检查第一列中的一行是否作为另一个文件中另一行的一部分存在。例如,如果我有以下文件: a、 txt: 0000_01_000000049E 7821069312 0000_01_000000049F 7886800896 0000_01_00000004A1 8302987264 0000_01_00000004A2 8469055488 0000_01_00000004A3 8040450048 0000_01_00000004A5 8250165248 0000_01_000000

我想知道如何检查第一列中的一行是否作为另一个文件中另一行的一部分存在。例如,如果我有以下文件:

a、 txt:

0000_01_000000049E 7821069312
0000_01_000000049F 7886800896
0000_01_00000004A1 8302987264
0000_01_00000004A2 8469055488
0000_01_00000004A3 8040450048
0000_01_00000004A5 8250165248
0000_01_00000004A6 8116242432
0000_01_00000004A7 8260126720
0000_01_00000004A9 6420892672
0000_01_00000004AA 1076364288
0000_01_00000004AB 7822870528
0000_01_00000004AE 4297589760
0000_01_00000004AF 2360320
b、 txt:

0000_01_000000049E,000000,0000_02_00000002AA,7821070336,1451596986,L3,0,0
0000_01_000000049F,000001,0000_02_00000002AA,7886801920,1451623534,L3,0,0
0000_01_00000004A0,000002,0000_02_00000002AA,6888983552,1451051126,L3,0,0
0000_01_00000004A1,000003,0000_02_00000002AA,8302988288,1451618939,L3,0,0
0000_01_00000004A2,000004,0000_02_00000002AA,8469056512,1451605811,L3,0,0
0000_01_00000004A3,000005,0000_02_00000002AA,8040451072,1452180174,L3,0,0
0000_01_00000004A4,000006,0000_02_00000002AA,8569819136,1451541232,L3,0,0
0000_01_00000004A5,000007,0000_02_00000002AA,8250166272,1452181606,L3,0,0
0000_01_00000004A6,000008,0000_02_00000002AA,8116243456,1452013786,L3,0,0
0000_01_00000004A7,000009,0000_02_00000002AA,8260127744,1451420337,L3,0,0
0000_01_00000004A8,000010,0000_02_00000002AA,8454605824,1451542793,L3,0,0
0000_01_00000004A9,000011,0000_02_00000002AA,7543657472,1451568105,L3,0,0
0000_01_00000004AA,000012,0000_02_00000002AA,7654181888,1451494089,L3,0,0
0000_01_00000004AB,000013,0000_02_00000002AA,7822871552,1451590252,L3,0,0
0000_01_00000004AC,000014,0000_02_00000002AA,5295639552,1450925203,L3,0,0
0000_01_00000004AD,000015,0000_02_00000002AA,7793807360,1451470796,L3,0,0
0000_01_00000004AE,000016,0000_02_00000002AA,8330842112,1451591997,L3,0,0
0000_01_00000004AF,000017,0000_02_00000002AA,29039368192,1452093213,L3,0,0
我想返回文件“b.txt”中第二列的值,其中文件“a.txt”和“b.txt”中第一列的值匹配(有点像内部联接)。因此,如果该文件位于输出文件“c.txt”中,我希望获得以下输出:

c、 txt:

000000
000001
000002
000003
000004
000005
000007
000008
000009
000011
000012
000013
000016
000017
请注意,这些值在文件“b.txt”的第二列中不存在:

我试着到处找,但找不到任何具体的解决办法。谢谢你的帮助


谢谢

您可以使用
awk

awk -F '[, ]' 'FNR==NR{col1[$1]; next} $1 in col1{print $2}' a.txt b.txt
000000
000001
000003
000004
000005
000007
000008
000009
000011
000012
000013
000016
000017

这一行应该适合您:

awk 'NR==FNR{a[$1];next}$1 in a{print $2}' a.txt FS=',' b.txt

您的两个文件有不同的分隔符,我们必须为b.txt设置FS=',我建议像其他人建议的那样使用
awk
。但是,仅使用GNU coreutils也可以解决该任务:

join -1 1 -2 1 <(tr ',' ' ' < b.txt | sort) <(sort a.txt) | cut -d' ' -f2

join-11-21有多个类似的问题。你检查过了吗?你尝试了什么?是的,我在类似的问题上找到了类似的答案,但它们并不是我所需要的,我无法修改给定的答案以适合我的解决方案。我正要发布几乎相同的答案。这可以缩短为
join-o2.2a.txt。你能解释一下这个脚本是如何工作的吗?我想尝试一下我自己的文件格式不同,但不能告诉我需要调整。谢天谢地,这实际上是使用awk的标准2文件处理,您不清楚哪一部分?
join -1 1 -2 1 <(tr ',' ' ' < b.txt | sort) <(sort a.txt) | cut -d' ' -f2
join -o 2.2 a.txt <(tr ',' ' ' < b.txt)