Python代码列表怎么求并集,交集,差集

技术Python代码列表怎么求并集,交集,差集本篇内容介绍了“Python代码列表怎么求并集,交集,差集”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希

本文介绍了“如何在Python代码列表中找到并集、交集和差集”的知识。在实际的案件操作过程中,很多人都会遇到这种困境。接下来,让边肖带领大家学习如何应对这些情况!希望大家认真阅读,学点东西!

一、列表求并集

实现了查找两个列表并集的功能。同时支持过滤条件函数,根据过滤条件函数将列表中的所有元素进行组合,集中两个列表的原始元素。

我们阅读本文的代码片段来自30秒的python。

1. union_by

defo nion _ by(a,b,fn):

_a=set(map(fn,a))

return list(set(a[itemforiteminiffn(item)notin _ a])

#示例

来自mathimportfloor

Union _ by ([2.1],[1.2,2.3],floor) # [2.1,1.2] Union _ by函数接收两个列表和一个筛选条件函数。将提供的函数应用于两个列表中的每个元素后,将返回一个新列表,其中包含两个列表中存在的所有非重复元素。

map函数之前已经解释过了,它将返回一个迭代器,该迭代器将把转换函数fn应用于所有列表元素。

Set Python是一种特殊的数据类型,它是一组无序的非重复元素。该函数直接使用集合类型来消除列表中的重复元素。

特别地,当过滤条件函数是lamda x:x时,该函数被转换成直接寻找两个列表的并集。

二、列表求交集

实现了两个列表的交集功能。同时支持过滤条件函数,根据过滤条件函数列表中的所有元素都得到交集,交集集就是两个列表的原始元素。

1. intersection_by

define section _ by(a,b,fn):

_b=set(map(fn,b))

返回[itemforiteminiffn(item)in _ b]

#示例

来自mathimportfloor

Section _ by ([2.1,1.2],[2.3,3.4],floor) # [2.1] Section _ by函数接收两个列表和一个筛选条件函数。将提供的函数应用于两个列表中的每个元素后,它会返回存在于两个列表中的元素列表。该函数通过对B中的每个元素应用fn来创建一个集合,然后在A上一起使用列表派生和fn来仅保留两个列表中存在的值。

map函数之前已经解释过了,它将返回一个迭代器,该迭代器将把转换函数fn应用于所有列表元素。

Set Python是一种特殊的数据类型,它是一组无序的非重复元素。该函数直接使用集合类型来消除列表中的重复元素。

特别的:滤波条件函数为lamda x:x时,该函数转化为直接求两个列表的交集。

三、列表求差集

实现了三种不同的列表差异设置方式。它们是列表的直接差,其中列表中的所有元素根据条件函数计算difference_by,列表中的所有元素根据条件函数计算对称差difference _ difference _ by。

1. difference

defdifference(a,b):

_ b=设置(b)

返回[itemforiteminifitemnitin _ b]

#示例

差([1,2,3],nb

sp;[1, 2, 4]) # [3]

difference函数返回两个可迭代对象之间的差。该函数从b中创建一个集合_b,然后在a上使用列表推导式,只保留_b中不包含的值。该函数中a和b是有顺序关系的,a-b是从a中删除b中包含的数据。

setPython的一个特殊的数据类型,是由不重复元素组成的无序的集。本函数直接使用set类型消除了列表中的重复元素。

2. 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时,函数转化为直接求取两个列表的差。

3. 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时,函数转化为直接求取两个列表的对称差。

“Python代码列表怎么求并集,交集,差集”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注网站,小编将为大家输出更多高质量的实用文章!

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/86826.html

(0)

相关推荐

  • c语言socket编程流程(c语言socket编程怎么实现)

    技术如何使用C语言实现本地socke通讯这篇文章主要介绍了如何使用C语言实现本地socke通讯,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一、概述  使

    攻略 2021年12月20日
  • 怎么备份微信聊天记录,微信6.3.1怎样备份聊天记录

    技术怎么备份微信聊天记录,微信6.3.1怎样备份聊天记录第一种怎么备份微信聊天记录、通过微信的聊天记录迁移保存 这个方式无论是安卓手机和苹果手机都可以,方法如下:
    打开设置——通用——聊天记录迁移——选择需要上传的信息

    生活 2021年10月29日
  • ADO.NET存储过程调用举例分析

    技术ADO.NET存储过程调用举例分析这篇文章主要讲解了“ADO.NET存储过程调用举例分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“ADO.NET存储过程调用举例分

    攻略 2021年12月3日
  • 0094-leetcode算法实现之二叉树中序遍历-binary-tree-inorder-traversal-pythongolang实现

    技术0094-leetcode算法实现之二叉树中序遍历-binary-tree-inorder-traversal-pythongolang实现 0094-leetcode算法实现之二叉树中序遍历-bi

    礼包 2021年11月12日
  • c#中如何生成一个每小时变化一次的用户名

    技术c#中如何生成一个每小时变化一次的用户名这篇文章将为大家详细讲解有关c#中如何生成一个每小时变化一次的用户名,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。在做一个ASP.NET的项

    攻略 2021年11月23日
  • 方程式题目五年级,小学五年级数学应用题目什么没有

    技术方程式题目五年级,小学五年级数学应用题目什么没有某小学一班植树48棵,比二班少植树8棵,二班植树多少棵?人民小学食堂运来400千克大米,已经吃了5分之2,还剩多少千克?用一张边长20厘米的正方形纸,裁剪粘贴成一个无盖

    生活 2021年10月23日