乐趣区

关于python:Python代码阅读第16篇列表求差集

Python 代码浏览合集介绍:为什么不举荐 Python 初学者间接看我的项目源码

本篇浏览三种不同的列表差集的实现形式。别离是列表间接求差difference,列表中所有元素依据条件函数求差difference_by,列表中所有元素依据条件函数求对称差symmetric_difference_by

本篇浏览的代码片段来自于 30-seconds-of-python。

difference

def difference(a, b):
  _b = set(b)
  return [item for item in a if item not in _b]

# EXAMPLES
difference([1, 2, 3], [1, 2, 4]) # [3]

difference函数返回两个可迭代对象之间的差。该函数从 b 中创立一个汇合 _b,而后在a 上应用列表推导式,只保留 _b 中不蕴含的值。该函数中 ab是有程序关系的,a-b是从 a 中删除 b 中蕴含的数据。

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

difference_by

def difference_by(a, b, fn):
  _b = set(map(fn, b))
  return [item for item in a if fn(item) not in _b]

# EXAMPLES
from math import floor
difference_by([2.1, 1.2], [2.3, 3.4], floor) # [1.2]
difference_by([{'x': 2}, {'x': 1}], [{'x': 1}], lambda v : v['x']) # [{ x: 2} ]

difference_by函数接管两个列表和一个过滤条件函数。将提供的函数利用于两个列表中的每个元素后,返回两个原始列表的差。函数通过对 b 中的每个元素利用 fn 来创立一个汇合,而后在 a 上应用列表推导式与 fn 相结合,只保留之前创立的汇合 _b 中没有蕴含的值。

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

symmetric_difference_by

def symmetric_difference_by(a, b, fn):
  _a, _b = set(map(fn, a)), set(map(fn, b))
  return [item for item in a if fn(item) not in _b] + [item for item in b if fn(item) not in _a]

# EXAMPLES
from math import floor
symmetric_difference_by([2.1, 1.2], [2.3, 3.4],floor) # [1.2, 3.4]

symmetric_difference_by函数对两个列表中的每个列表元素利用所提供的函数后,返回两个原始列表之间的对称差。函数通过别离对每个列表中的每个元素利用 fn 来创立两个汇合 _a_b,而后在每个元素上应用列表了解与 fn 相结合,只保留不蕴含在之前创立的其余汇合中的值(在 a 中,不在_b 中;在 b 中,不在 _a 中。)。

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

退出移动版