更快的列表理解

Posted

技术标签:

【中文标题】更快的列表理解【英文标题】:Faster list comprehension 【发布时间】:2021-03-02 11:14:00 【问题描述】:

我有两个元素为元组的列表。

lst1 = [(101, 201), (102, 203), (103, 204)]
lst2 = [(1, 101, 201), (2, 101, 202), (3, 102, 203), (4, 103, 204), (5, 103, 205)]

如果第二个和第三个项目与第一个列表中的元组匹配,我需要输出第二个列表中元组中的第一个项目。我正在使用列表理解并获得预期的结果,但我在两个列表中都有近百万个元素,所以它太慢了。

out_lst = [x[0] for x in lst2 if (x[1], x[2]) in lst1]

# Output
[1, 3, 4]

有没有更快的方法?

【问题讨论】:

您能检查一下set(lst1)(在循环之外创建)吗? 【参考方案1】:

您可以使用set,因为搜索set 对象的时间是恒定的。

lst1 = [(101, 201), (102, 203), (103, 204)]
lst2 = [(1, 101, 201), (2, 101, 202), (3, 102, 203), (4, 103, 204), (5, 103, 205)]
set1 = set(lst1)
res = [x[0] for x in lst2 if (x[1], x[2]) in set1]

【讨论】:

以上是关于更快的列表理解的主要内容,如果未能解决你的问题,请参考以下文章

星图比嵌套列表理解更快吗?

比较列表理解和显式循环(3 个数组生成器比 1 个 for 循环更快)

如何提高熊猫数据框的列表理解速度

python:reduce 可以翻译成 map、lambda 和 filter 之类的列表理解吗?

查找不在列表 A 但列表 B 中的人员的更快方法 [重复]

搜索列表的更快方法?