共计 529 个字符,预计需要花费 2 分钟才能阅读完成。
Python 代码浏览合集介绍:为什么不举荐 Python 初学者间接看我的项目源码
本篇浏览的代码实现了实现了两个列表求并集的性能。同时反对应用一个过滤条件函数,列表中所有元素依据该条件求取并集,并集中是两个列表的原始元素。
本篇浏览的代码片段来自于 30-seconds-of-python。
union_by
def union_by(a, b, fn):
_a = set(map(fn, a))
return list(set(a + [item for item in b if fn(item) not in _a]))
# EXAMPLES
from math import floor
union_by([2.1], [1.2, 2.3], floor) # [2.1, 1.2]
union_by
函数接管两个列表和一个过滤条件函数。将提供的函数利用于两个列表中的每个元素后,返回一个新的列表,蕴含所有存在于两个列表的不反复的元素。
map
函数之前曾经解说过,它会返回一个迭代器,该迭代器会将变换函数 fn
利用于所有的列表元素上。
set
是 Python
的一个非凡的数据类型,是由不反复元素组成的无序的集。本函数间接应用 set
类型打消了列表中的反复元素。
特地的,当过滤条件函数是 lamda x:x
时,函数转化为间接求取两个列表的并集。
正文完