关于python:Python代码阅读第14篇列表求并集

43次阅读

共计 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 利用于所有的列表元素上。

setPython 的一个非凡的数据类型,是由不反复元素组成的无序的集。本函数间接应用 set 类型打消了列表中的反复元素。

特地的,当过滤条件函数是 lamda x:x 时,函数转化为间接求取两个列表的并集。

正文完
 0