0

0

Python集合怎么求差集_difference与-运算符对比过滤

P粉602998670

P粉602998670

发布时间:2026-03-17 13:07:13

|

275人浏览过

|

来源于php中文网

原创

<p>是,set_a.difference(set_b) 与 set_a - set_b 等价,但 difference() 支持任意可迭代对象,- 要求右侧必须为 set;多参数、None 安全性、可读性及原地更新方面 difference() 更健壮。</p>

python集合怎么求差集_difference与-运算符对比过滤

difference() 和 - 运算符结果一样吗?

一样,只要操作对象都是 set 类型,set_a.difference(set_b)set_a - set_b 语义完全等价,返回新集合,不修改原集合。

但注意:如果右边不是 set(比如是 listtuple),difference() 能接,- 会直接报错 TypeError: unsupported operand type(s)

  • set_a.difference([1, 2, 3]) ✅ 合法,自动转为集合再计算
  • set_a - [1, 2, 3] ❌ 报错,必须是 set
  • 多参数时:set_a.difference(b, c, d) 等价于 set_a - b - c - d,但后者要写三次 -,可读性差

为什么有时候用 difference() 更安全?

因为 difference() 支持任意可迭代对象,而 - 强制要求右侧是 set。实际中你拿到的数据经常是 listdict_keys 或生成器,硬转 set 不仅多写代码,还可能意外消耗迭代器或引入空值问题。

  • 常见场景:从数据库查出 ID 列表 excluded_ids = [101, 205, 307],想过滤掉已存在的 all_items 集合 → 直接 all_items.difference(excluded_ids)
  • 若用 -,得先写 all_items - set(excluded_ids),多一次构造开销,且如果 excluded_ids 是生成器,set() 会一次性取尽
  • difference() 内部做了类型适配,对性能影响微乎其微,但代码更稳

链式差集:- 比 difference() 更难读?

当要连续减多个集合时,- 看似简洁,实则容易误读结合顺序或漏括号;difference() 参数列表一目了然。

Spell.tools
Spell.tools

高颜值AI内容营销创作工具

下载

立即学习Python免费学习笔记(深入)”;

  • a - b - c 等价于 (a - b) - c,没问题,但多人协作时有人会下意识以为是 a - (b - c)
  • a.difference(b, c) 明确表示“从 a 中剔除 b 和 c 的所有元素”,无歧义
  • 如果其中某个变量可能是 Nonedifference() 可加判断:a.difference(b or set());而 a - (b or set()) 一旦 bNone 就直接炸

性能差异大吗?

基本没差别。底层都是哈希遍历,时间复杂度 O(n),常数项也接近。但在极端情况(比如超大集合 + 多次调用)下,difference() 因为函数调用开销略高一点点,不过通常测不出来。

  • 别为这点差异换写法,优先看可读性和健壮性
  • 真正影响性能的是「是否重复构造临时集合」:比如 set_a - set(list_b) 每次都新建 set,不如缓存 set_b = set(list_b) 再用 -difference()
  • 如果要原地修改,用 set_a.difference_update(b),它比 set_a -= b 更通用(同样支持任意可迭代对象)

实际用哪个,取决于你手里的数据是不是现成的 set。不是的话,别硬套 -difference() 不是备选,是默认选择。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1570

2023.10.24

Go语言中的运算符有哪些
Go语言中的运算符有哪些

Go语言中的运算符有:1、加法运算符;2、减法运算符;3、乘法运算符;4、除法运算符;5、取余运算符;6、比较运算符;7、位运算符;8、按位与运算符;9、按位或运算符;10、按位异或运算符等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

241

2024.02.23

php三元运算符用法
php三元运算符用法

本专题整合了php三元运算符相关教程,阅读专题下面的文章了解更多详细内容。

170

2025.10.17

数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

391

2023.06.29

如何删除数据库
如何删除数据库

删除数据库是指在MySQL中完全移除一个数据库及其所包含的所有数据和结构,作用包括:1、释放存储空间;2、确保数据的安全性;3、提高数据库的整体性能,加速查询和操作的执行速度。尽管删除数据库具有一些好处,但在执行任何删除操作之前,务必谨慎操作,并备份重要的数据。删除数据库将永久性地删除所有相关数据和结构,无法回滚。

2113

2023.08.14

vb怎么连接数据库
vb怎么连接数据库

在VB中,连接数据库通常使用ADO(ActiveX 数据对象)或 DAO(Data Access Objects)这两个技术来实现:1、引入ADO库;2、创建ADO连接对象;3、配置连接字符串;4、打开连接;5、执行SQL语句;6、处理查询结果;7、关闭连接即可。

359

2023.08.31

MySQL恢复数据库
MySQL恢复数据库

MySQL恢复数据库的方法有使用物理备份恢复、使用逻辑备份恢复、使用二进制日志恢复和使用数据库复制进行恢复等。本专题为大家提供MySQL数据库相关的文章、下载、课程内容,供大家免费下载体验。

259

2023.09.05

vb中怎么连接access数据库
vb中怎么连接access数据库

vb中连接access数据库的步骤包括引用必要的命名空间、创建连接字符串、创建连接对象、打开连接、执行SQL语句和关闭连接。本专题为大家提供连接access数据库相关的文章、下载、课程内容,供大家免费下载体验。

329

2023.10.09

c++ 字符处理
c++ 字符处理

本专题整合了c++字符处理教程、字符串处理函数相关内容,阅读专题下面的文章了解更多详细内容。

0

2026.03.17

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 5.1万人学习

SciPy 教程
SciPy 教程

共10课时 | 2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号