gpt4 book ai didi

python - 比较同一位置相同条目的两个列表

转载 作者:太空宇宙 更新时间:2023-11-04 10:03:50 25 4
gpt4 key购买 nike

我正在尝试比较同一索引处同一元素的两个列表。这个想法是验证两个列表是否在同一索引处包含相同的元素。如果是,我想计算此类事件的发生次数。这是我的代码:

 count = 0
a = ['.ps2\n >|<4 *|*.ps2xml', '.c\n >|<2 *|*.wsc', '.h\n >|<2 *|*.wsh', '.c\n >|<2 *|*.chm', '.h\n >|<2 *|*.hta' ]
b = ['.ps2xml', '.chm', '.hta']

for x in a:
for y in b:
if y==x[x.index(" *|*")+4:]:
print "match"
count += 1

print count

这给了我 3 的计数。我期望的是 1,因为只有 b 的第一个元素与 a 的第一个元素匹配。两个列表的第二个元素不同。第三要素也不同。列表 a 中的剩余元素不应计算在内,因为 b 中没有这样的索引。

希望这是有道理的。谢谢

最佳答案

在这种情况下,您不应该使用嵌套循环(因为这意味着您将对 a 中的每一行重复搜索 b ); 但使用zip(..):

for x,y in zip(a,b):
if y==x[x.index(" *|*")+4:]:
print "match"
count += 1

print count

zip 采用一些迭代器并生成元组。在这种情况下,第 i 个元组因此可以说是 (a[i],b[i])

关于python - 比较同一位置相同条目的两个列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42029873/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com