获得两个2D列表之间的差异

时间:2013-09-29 19:56:32

标签: python list

我有一个列表的2D列表,我正在做一些东西并获得,结果是略微修改的2d列表列表。在我收到新列表之前,我无法跟踪正在进行的更改。我想获得所有已更改的项目列表 [[1,2,3], [4,5,6], [7,8,9]]成为[[1,None,3], [4,None,6], [7,None, None]]我会得到一个列表[(0,1), (1,1), (2, 1), (2,2)]我知道你通常可以做list(set(a)-set(b))但是当我尝试它时我得到了TypeError: unhashable type: 'list'那么什么是最有效的方法吗?

3 个答案:

答案 0 :(得分:4)

使用zipenumerate和生成器函数:

def diff(lis1, lis2):
    for i, (x, y) in enumerate(zip(lis1, lis2)):
        for j, (x1, y1) in enumerate(zip(x, y)):
            if x1 != y1:
                yield i, j
...                 
>>> lis1 = [[1,2,3], [4,5,6], [7,8,9]]
>>> lis2 = [[1,None,3], [4,None,6], [7,None, None]]
>>> list(diff(lis1, lis2))
[(0, 1), (1, 1), (2, 1), (2, 2)]

答案 1 :(得分:3)

使用列表理解:

>>> a = [[1,2,3], [4,5,6], [7,8,9]]
>>> b = [[1,None,3], [4,None,6], [7,None, None]]
>>> [(i,j) for i, row in enumerate(a) for j, x in enumerate(row) if b[i][j] != x]
[(0, 1), (1, 1), (2, 1), (2, 2)]

答案 2 :(得分:0)

如果列表具有常规结构,即每个子列表具有相同的长度,并且您不介意使用外部包,numpy可以提供帮助。

import numpy as np
a = np.array([[1,2,3], [4,5,6], [7,8,9]])
b = np.array([[1,None,3], [4,None,6], [7,None, None]])

print(np.where(a!=b))

>>>(array([0, 1, 2, 2]), array([1, 1, 1, 2]))