比较两个在Python中顺序和重复很重要的浮点列表

时间:2019-02-28 23:22:05

标签: python list difference

我想比较两个列表之间的位置和价值差异。我需要知道listBlistA有多相似,不仅包含相同的值,而且这些值在相同的位置。

from collections import Counter

listA = [0.01, 0.02, 0.04, 0.03]
listB = [0.01, 0.02, 0.03, 0.04]

def compareListMethod1(a, b):
    return set(a).intersection(b)

def compareListMethod2(a, b):
    c1 = Counter(a)
    c2 = Counter(b)
    diff = c1-c2
    return list(diff.elements())

def compareListMethod3(a, b):
    count = Counter(a) # count items in a
    count.subtract(b)  # subtract items that are in b
    diff = []
    for x in a:
        if count[x] > 0:
           count[x] -= 1
           diff.append(x)
    return diff

print(compareListMethod1(listA, listB)) # returns {0.02, 0.01, 0.04, 0.03}
print(compareListMethod2(listA, listB)) # returns []
print(compareListMethod3(listA, listB)) # returns []

所需的输出将显示两个列表彼此不同的次数。在这种情况下,前两个条目是准确的,但是索引2和3处的条目是不同的-因此两个列表之间存在2个差异。

感谢您提供任何指导!

1 个答案:

答案 0 :(得分:2)

如果我理解正确,则应该可以:

sum(a != b for a, b in zip(listA, listB))

给出2的预期输出。

请注意,因为您的问题描述指出顺序很重要,所以在这里集将没有用,因为它们没有顺序。