Python-比较2个文件和输出差异

我的目标是编写一个脚本来比较文件中的每一行,并基于此比较,创建一个新文件,其中包含第二个文件中没有的文本行.

例如;

**File 1:** 

Bob:20 
Dan:50 
Brad:34 
Emma:32 
Anne:43

**File 2:**

Dan:50
Emma:32
Anne:43

新的输出(文件3):

Bob:20
Brad:34

我对如何完成此操作有一些想法,但不完全是:

def compare(File1,File2):
   with open(File1, "a") as f1:
       lines = f1.readlines()
       string = line.split(':')
   with open(File2, "a") as f2:
       lines = f2.readlines()
       string2 = line.split(':')
       if string[0] == string[1]:
           with open("newfile2.txt", "w") as f3:
            ....

我想我需要一些类似的内容,然后比较每个文件的每一行中的string [0],但是从这一点来看我真的很笨.

任何帮助都将受到极大的欢迎.

解决方法:

这为我工作:

def compare(File1,File2):
    with open(File1,'r') as f:
        d=set(f.readlines())


    with open(File2,'r') as f:
        e=set(f.readlines())

    open('file3.txt','w').close() #Create the file

    with open('file3.txt','a') as f:
        for line in list(d-e):
           f.write(line)

您需要比较设置的readlines,并找出file2中不存在的行.然后,您可以将这些行附加到新文件中.

上一篇:在bash(Linux)中从另一个csv(如vlookup)中查找值


下一篇:javascript – 不可变JS比较嵌套结构