Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/video/2.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
Bash 比较不同文件中的值并保留不匹配的行_Bash - Fatal编程技术网

Bash 比较不同文件中的值并保留不匹配的行

Bash 比较不同文件中的值并保留不匹配的行,bash,Bash,我有两个文件,其中包含SQL数据,我希望删除第二个文件中的数据,该文件具有匹配的课程代码和学生编号。文件如下所示: 文件1: INSERT INTO RegisteredCourses (course,student) VALUES ('BKE974','3941021693'); INSERT INTO RegisteredCourses (course,student) VALUES ('BKE974','5044463260'); INSERT INTO RegisteredCourses

我有两个文件,其中包含SQL数据,我希望删除第二个文件中的数据,该文件具有匹配的课程代码和学生编号。文件如下所示:

文件1:

INSERT INTO RegisteredCourses (course,student) VALUES ('BKE974','3941021693');
INSERT INTO RegisteredCourses (course,student) VALUES ('BKE974','5044463260');
INSERT INTO RegisteredCourses (course,student) VALUES ('BKE974','5923001715');
INSERT INTO RegisteredCourses (course,student) VALUES ('DQY359','7539643746');
INSERT INTO RegisteredCourses (course,student) VALUES ('DQY359','9604636424');
INSERT INTO RegisteredCourses (course,student) VALUES ('DQY359','9649249670');
文件2:

INSERT INTO Queue (course,student,registrationDate) VALUES ('BKE974','3941021693','1354811709');
INSERT INTO Queue (course,student,registrationDate) VALUES ('BKE974','5044463260','1378352712');
INSERT INTO Queue (course,student,registrationDate) VALUES ('BKE974','3421728825','1368144500');
INSERT INTO Queue (course,student,registrationDate) VALUES ('DQY359','7421758823','1375874278');
INSERT INTO Queue (course,student,registrationDate) VALUES ('DQY359','9604636424','1374587707');
INSERT INTO Queue (course,student,registrationDate) VALUES ('DQY359','9649249670','1370542279');
我已经处理了这些文件,以便课程和学生字段在文件的前两行和后两行匹配。在第一行中,您可以看到它们具有相同的课程(BKE974)和学生(3941021693)值。如果这些值不匹配,我想将File2中的整行打印到一个新文件中

我一直在尝试使用一些bash脚本来解决这个问题,我希望有一个bash解决方案,因为我正在尝试了解更多关于bash的信息。我曾尝试使用grep、awk和cut来解决这个问题,但我对bash的知识非常缺乏:P

编辑: 因此,我希望得到的结果应该是将这两行打印到一个新文件中:

 INSERT INTO Queue (course,student,registrationDate) VALUES ('BKE974','3421728825','1368144500');
 INSERT INTO Queue (course,student,registrationDate) VALUES ('DQY359','7421758823','1375874278');
试试这个

#!/bin/bash
    while read line
    do
            x=`echo "$line" | sed -n "s/.*VALUES (//p" | sed -n "s/);//p"`;
            sed -i   '/'$x'/d' file2.txt
    done<file1.txt
#/bin/bash
读行时
做
x=`echo“$line”| sed-n“s/*值(//p”| sed-n“s/);//p”`;
sed-i'/'$x'/d'file2.txt

完成这里有一种方法使用
GNU awk

awk -F "[()]" 'FNR==NR { a[$(NF-1)]++; next } !(gensub(/(.*),.*/,"\\1","g",$(NF-1)) in a)' File1 File2
结果:

INSERT INTO Queue (course,student,registrationDate) VALUES ('BKE974','3421728825','1368144500');
INSERT INTO Queue (course,student,registrationDate) VALUES ('DQY359','7421758823','1375874278');

谢谢,这打印了一个似乎是独特的课程和学生的列表。但我想打印完整的行以保持insert语句的完整。这不仅打印值。检查文件2.txt。。找到的所有条目也将被删除..我已删除echo$x。。因为这是不需要的。。。你想打印什么??对不起,我不太清楚。我更新了这个问题,也展示了我想要得到的结果。太棒了。你是上帝:)。这将需要我几年的时间来破译,但它是有效的:D