1

使用 difflib.compare 和 python 来比较两个文本文件。我知道比较本质上返回一个字符串列表。当字符串对于第一个文本文件是唯一的时,它会在字符串之前放置一个“-”,当字符串对于第二个文本文件是唯一的时,它会在字符串之前放置一个“+”。

我的问题是我正在尝试编写一些代码来确定要保留哪个字符串。我目前开始在每个字符串中寻找“-”,如果找到它,我会执行一些逻辑来确定我是否要使用该字符串。如果我不打算使用它,那么我要么往下看一两行“+”。

在我的几乎所有情况下,“-”行都在“+”行之前。但现在我得到了“+”行在“-”行之前的实例。这是抛弃我的代码,因为它找不到正确的行来写入输出文本文件。有谁知道字符串如何写入数组背后的逻辑是基于哪个行号先出现?

ex//
majority of the time out put is this:
"-    color: #ffffff;"
"+    color: #785642;"

but rarely it does come out the opposite:
"+    color: #785642;"
"-    color: #ffffff;"
4

1 回答 1

0
DIFFERENCE_OUTPUT = []

def find_differences(list1, list2):
    list1 = sorted(list1)
    list2 = sorted(list2)
    for diff in difflib.ndiff(list1,list2): 
        DIFFERENCE_OUTPUT.append(diff)
    for line in DIFFERENCE_OUTPUT:
        if line.startswith("-"):
            #I would suggest change the '-' to the name of the file and print line to see what is there
            line = line.replace('-','NAME of List')
            print(line)
            ****preform task
        elif line.startswith("+"):
            ****preform task

所有的“-”都应该用于 list1,所有“+”都应该用于 list2。如果您在“-”之前看到“+”,则表示 list2 有输出,但 list1 没有,反之亦然。

于 2013-11-12T17:36:08.760 回答