list_1 = ['a', 'a', 'a', 'b']
list_2 = ['a', 'b', 'b', 'b', 'c']
所以在上面的列表中,只有索引 0 中的项目是相同的,而两个列表中的索引 1 到 4 是不同的。此外,list_2
有一个额外的项目 'c'
。
我想计算两个列表中索引不同的次数,在这种情况下我应该得到 3。
我试过这样做:
x = 0
for i in max(len(list_1),len(list_2)):
if list_1[i]==list_2[i]:
continue
else:
x+=1
我遇到了一个错误。
最佳答案
使用 zip()
function将列表配对,计算所有差异,然后添加长度差异。
zip()
只会迭代可以配对的项目,但迭代其余部分没有什么意义;你知道这些都算作不同:
differences = sum(a != b for a, b in zip(list_1, list_2))
differences += abs(len(list_1) - len(list_2))
sum()
求和 True
和 False
值;这是可行的,因为 Python 的 boolean
类型是 int
的子类,而 False
等于 0
,True
等于 1
。因此,对于每对不同的元素,!=
测试生成的 True
值加起来为 1
。
演示:
>>> list_1 = ['a', 'a', 'a', 'b']
>>> list_2 = ['a', 'b', 'b', 'b', 'c']
>>> sum(a != b for a, b in zip(list_1, list_2))
2
>>> abs(len(list_1) - len(list_2))
1
>>> difference = sum(a != b for a, b in zip(list_1, list_2))
>>> difference += abs(len(list_1) - len(list_2))
>>> difference
3
关于python比较2个不同长度列表中的项目-顺序很重要,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30791974/