繁体   English   中英

快速迭代元组列表

[英]iterating quickly through list of tuples

我想知道是否有更快,更省时的方法来迭代元组列表,找到正确的匹配。 我所做的是:

# this is a very long list.
my_list = [ (old1, new1), (old2, new2), (old3, new3), ... (oldN, newN)]

# go through entire list and look for match
for j in my_list:
    if j[0] == VALUE:
        PAIR_FOUND = True
        MATCHING_VALUE = j[1]
        break

此代码可能需要相当长的时间才能执行,具体取决于列表中的项目数。 我相信有更好的方法可以做到这一点。

我认为你可以使用

for j,k in my_list:
  [ ... stuff ... ]

假设更多的内存使用不是问题,如果你的元组的第一项是可清除的,你可以从元组列表中创建一个字典 ,然后查找值就像从dict查找键一样简单。 就像是:

dct = dict(tuples)
val = dct.get(key) # None if item not found else the corresponding value

编辑 :要创建反向映射,请使用以下内容:

revDct = dict((val, key) for (key, val) in tuples)

这个问题已经死了但仍然知道另一种方式并没有伤害:

my_list = [ (old1, new1), (old2, new2), (old3, new3), ... (oldN, newN)]

for first,*args in my_list:
    if first == Value:
        PAIR_FOUND = True
        MATCHING_VALUE = args
        break

可以清除代码,但如果使用列表来存储元组,则任何此类查找都将为O(N)。

如果查找速度很重要,您应该使用dict来存储元组。 键应该是元组的第0个元素,因为那是你正在搜索的内容。 您可以从列表中轻松创建一个字典:

my_dict = dict(my_list)

然后, (VALUE, my_dict[VALUE])将为您提供匹配的元组(假设存在VALUE )。

我想知道下面的方法是否是你想要的。

您可以使用defaultdict

>>> from collections import defaultdict
>>> s = [('red',1), ('blue',2), ('red',3), ('blue',4), ('red',1), ('blue',4)]
>>> d = defaultdict(list)
>>> for k, v in s:
       d[k].append(v)    
>>> sorted(d.items())
[('blue', [2, 4, 4]), ('red', [1, 3, 1])]

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM