百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

Python 中 必须掌握的 20 个核心函数——set()详解

off999 2025-09-09 09:26 50 浏览 0 评论

set()是Python中用于创建集合的核心函数,集合是一种无序、不重复元素的容器,非常适合用于成员检测、去重和数学集合运算

一、set()的基本用法

1.1 创建空集合

# 创建空集合
empty_set = set()
print(empty_set)  # set()

# 注意:{}创建的是空字典,不是空集合
not_a_set = {}
print(type(not_a_set))  # <class 'dict'>

1.2 从可迭代对象创建集合

# 从列表创建(自动去重)
numbers = set([1, 2, 2, 3, 3, 3])
print(numbers)  # {1, 2, 3}

# 从字符串创建(拆分为唯一字符)
letters = set("hello")
print(letters)  # {'h', 'e', 'l', 'o'}

# 从元组创建
unique_nums = set((1, 2, 2, 3))
print(unique_nums)  # {1, 2, 3}

# 从字典创建(获取键)
keys = set({'a': 1, 'b': 2})
print(keys)  # {'a', 'b'}

二、set()的高级特性

2.1 集合运算

a = {1, 2, 3}
b = {2, 3, 4}

# 并集
print(a | b)  # {1, 2, 3, 4}

# 交集
print(a & b)  # {2, 3}

# 差集
print(a - b)  # {1}

# 对称差集(仅在其中一个集合中的元素)
print(a ^ b)  # {1, 4}

2.2 集合推导式

# 创建平方数集合
squares = {x*x for x in range(5)}
print(squares)  # {0, 1, 4, 9, 16}

# 带条件的集合推导式
even_squares = {x*x for x in range(10) if x % 2 == 0}
print(even_squares)  # {0, 4, 16, 36, 64}

2.3 不可变集合frozenset

# 创建不可变集合
fs = frozenset([1, 2, 3])
print(fs)  # frozenset({1, 2, 3})

# fs.add(4)  # 报错:frozenset不可修改

三、set()的实际应用

3.1 高效去重

# 列表去重
duplicates = [1, 2, 2, 3, 3, 3]
unique = list(set(duplicates))
print(unique)  # [1, 2, 3](顺序可能不同)

# 文件行去重
with open('data.txt') as f:
    unique_lines = set(f.readlines())

3.2 快速成员检测

# 创建大型集合
large_set = set(range(1000000))

# 极速查找(O(1)时间复杂度)
%timeit 999999 in large_set  # 约100纳秒

# 对比列表查找(O(n)时间复杂度)
large_list = list(range(1000000))
%timeit 999999 in large_list  # 约10毫秒(慢100,000倍)

3.3 关系测试

# 查找共同好友
alice_friends = {"Bob", "Charlie", "Diana"}
bob_friends = {"Charlie", "Diana", "Eve"}

common_friends = alice_friends & bob_friends
print(common_friends)  # {'Charlie', 'Diana'}

四、常见问题解答

4.1 为什么集合元素是无序的?

集合基于哈希表实现,为提高查询效率牺牲了顺序性。Python 3.7+中字典保留插入顺序,但集合仍不保证顺序。

4.2 如何保持去重后的顺序?

from collections import OrderedDict

duplicates = [3, 1, 2, 1, 3]
unique_ordered = list(OrderedDict.fromkeys(duplicates))
print(unique_ordered)  # [3, 1, 2]

4.3 集合可以存储什么类型的元素?

集合元素必须是可哈希的(不可变类型):

  • 允许:数字、字符串、元组(仅包含不可变元素)
  • 不允许:列表、字典、集合(可使用frozenset替代)

4.4 如何判断两个集合是否相等?

a = {1, 2, 3}
b = {3, 2, 1}
print(a == b)  # True(集合不考虑顺序)

五、性能优化技巧

  1. 预分配空间(Python 3.6+):
s = set(range(1000000))  # 比逐步add更快
  1. 批量操作
# 优于多次add
s.update([4, 5, 6])
  1. 替代列表去重
# 更高效的去重方式
unique = list(dict.fromkeys(duplicates)))

六、总结

set()是Python中处理唯一性数据的核心工具,主要特点包括:

  • 自动去重:确保元素唯一性
  • 高效查询:O(1)时间复杂度的成员检测
  • 集合运算:支持并集、交集等数学操作
  • 内存效率:比列表更节省空间(对大型唯一数据集)

最佳实践建议

  1. 需要去重或快速查找时优先使用集合
  2. 大型数据集初始化时直接传入可迭代对象
  3. 注意元素必须可哈希的限制
  4. 需要顺序保留时考虑OrderedDict替代方案

相关推荐

分区助手给c盘扩容靠谱吗(分区助手 c盘扩容)

应该是盘符没有了,请重新设置一下盘符就可以了,不用使用恢复软件。直接用微软的磁盘管理工具就可以了,前提是你磁盘上有未分配的空间。如果没有可以用AcronisDiskDirectorSuite,这...

2025手机cpu性能排行榜(手机芯片天梯图2025)

骁龙870处理器华为Mate40Pro(麒麟9000)为例,麒麟9000芯片CPU采用1+3+4设计,一个大核为3.13GHz的A77、3个中核为2.54GHz的A77、4个2.05GHz的A55,...

电脑系统还原怎么关闭(电脑系统还原怎么关闭程序)

要关闭电脑系统还原功能,您可以按照以下步骤进行操作(适用于Windows系统):1.打开“控制面板”。您可以通过在Windows搜索栏中输入“控制面板”并点击打开,或者在开始菜单中找到“控制面板”并...

全国免费wifi万能钥匙(免费的wlan万能钥匙)

想上不是免费的WiFi,需要通过一定的技术手段,比如使用一些共享WiFi的软件,例如。WiFi万能钥匙或者是微信小程序的WiFi连一连,但这些都不是真正意义上的免费上网了,WiFi的密码都是通过别人...

安装win7卡在更新注册表设置

win7安装软件时卡在“正在注册字体”的原因是系统防火墙拦截导致的,具体解决方法步骤如下:1、首先打开计算机,敲击键盘上的“Ctrl+ALT+Del”键打开任务管理器。2、检查下是否有视频播放以及音影...

创新声卡win10 kx驱动(创新window10声卡驱动)

WIN10系统也是可以按现在KX驱动的,需要安装KX3552驱动才行。并且安装好以后,需要设置KX驱动的主程序为兼容WIN7系统运行才行。至于网络远程效果调试,也有便宜的,几十元就可以了。用KX3...

正在启动windows(正在启动windows后关机)

解决方法:1、打开电脑左下角“开始”菜单,找到“运行”选项,打开运行,输入services.msc命令,点击“确定”,进入服务项界面。? 2、找到printspooler服务右键,点击选择...

bt磁力资源天堂(bt磁力,几个技术拉近)

海盗湾 ThePirateBay海盗湾(ThePirateBay)一个提供BT种子文件和链接,以方便使用BT协议的对等文件共享网站。该网站于2003年在瑞典创建的。自2006年以来...

忘记自己家wifi密码怎么办(忘了自己家的wifi密码)
  • 忘记自己家wifi密码怎么办(忘了自己家的wifi密码)
  • 忘记自己家wifi密码怎么办(忘了自己家的wifi密码)
  • 忘记自己家wifi密码怎么办(忘了自己家的wifi密码)
  • 忘记自己家wifi密码怎么办(忘了自己家的wifi密码)
win10全屏任务栏不隐藏(win10全屏有任务栏)

1、在桌面空白处右击鼠标键,选择最下方的“个性化”按钮。2、点击选择左侧的“任务栏”按钮。3、进入任务设置窗口界面,找到其中的“在桌面模式下自动隐藏任务栏”字样。4、找到该字样下方的“开关”按钮。5、...

win10下载后怎么安装(win10安装后怎么下载软件)

安装Win10系统需要以下步骤:1.确定您的电脑是否符合安装Win10系统的要求,包括硬件和软件方面。2.下载最新的Win10系统镜像文件,并将其保存到一个可用的U盘或DVD中。3.打开电脑并插...

电脑如何添加字体(电脑如何添加字体到word字库里)

在电脑上添加新字体的步骤如下:1. 下载字体文件:从字体库网站或其他来源下载所需的字体文件,通常是以.ttf、.otf或.woff格式保存的文件。2. 解压缩字体文件:如果下载...

回收旧电脑一般能卖多少钱(回收旧电脑一般能卖多少钱一台)

废旧电脑回收价格一般在50-1200之间。这个比较难界定,不同牌子,不同型号,坏的配件不同,都可能造成不同。电脑回收一般会远低于买的时候的价格。一、你的电脑使用时间太长,配置都淘汰了。二、看上去很旧,...

pc软件下载网(pc软件官方免费下载)
  • pc软件下载网(pc软件官方免费下载)
  • pc软件下载网(pc软件官方免费下载)
  • pc软件下载网(pc软件官方免费下载)
  • pc软件下载网(pc软件官方免费下载)
最简单解除u盘写保护(u盘 解除写保护)

一、关闭写保护开关。有些U盘上面自带写保护的按钮,如果拨动到写保护状态时,就会对U盘进行写保护,这种情况解决的办法最简单,直接把开关拨回来即可。?写保护开关二、取消电脑写保护。1、如果是通过电脑对U盘...

取消回复欢迎 发表评论: