使用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;"发布于 2013-11-13 01:36:09
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没有,反之亦然。
https://stackoverflow.com/questions/19935408
复制相似问题