python set(集合)

简介:
set和dict类似,也是一组key的集合,但不存储value。由于key不能重复,所以,在set中,没有重复的key。
集合是一个无序的,不重复的数据组合,它的主要作用如下:
去重,把一个列表变成集合,就自动去重了
关系测试,测试两组数据之前的交集、差集、并集等关系
集合(set):把不同的元素组成一起形成集合,是python基本的数据类型。
集合元素(set elements):组成集合的成员(不可重复)

>>> li=[1,2,'a','b'] 
>>> s =set(li)
>>> print(s)             # {1, 2, 'a', 'b'}

>>> li2=[1,2,1,'a','a']
>>> s=set(li2)
>>> print(s)             #{1, 2, 'a'}      重复元素在set中自动被过滤:
 #注意,传入的参数[1, 2, 3]是一个list,而显示的{1, 2, 3}只是告诉你这个set内部有1233个元素,
 显示的顺序也不表示set是有序的。。

集合的相关操作  

1、创建集合

由于集合没有自己的语法格式,只能通过集合的工厂方法set()和frozenset()创建

>>> s1 = set('alvin')
>>> s2= frozenset('yuan')
>>> print(s1,type(s1))               #{'l', 'v', 'i', 'a', 'n'} <class 'set'>
>>> print(s2,type(s2))               #frozenset({'n', 'y', 'a', 'u'}) <class 'frozenset'>

2、访问集合

由于集合本身是无序的,所以不能为集合创建索引或切片操作,只能循环遍历或使用innot in来访问或判断集合元素。

>>> s1 = set('alvin')
>>> print('a' in s1)     #True
>>> print('b' in s1)     #False
>>> #s1[1]  #TypeError: 'set' object does not support indexing
>>> for i in s1:
>>>     print(i)        #l     i    n   v    a

3、更新集合

可使用以下内建方法来更新:

s.add()
s.update()

注意只有可变集合才能更新:

>>> #s1 = frozenset('alvin')
>>> #print(s1)           #frozenset({'a', 'n', 'i', 'v', 'l'})
>>> #s1.add("ccdc")      #AttributeError: 'frozenset' object has no attribute 'add'
>>> s2 = set('alvin')
>>> s2.add('mm')
>>> print(s2)  # {'mm', 'l', 'n', 'a', 'i', 'v'}
>>> s2.update('HO')  # 添加多个元素
>>> print(s2)  # {'mm', 'l', 'n', 'a', 'i', 'H', 'O', 'v'}

4、删除集合
s.remove()
>>> s2 = set('alvin')
>>> >>> print(s2)  # { 'l', 'n', 'a', 'i', 'v'}
>>> s2.remove('l')
>>> print(s2)  # {'n', 'a', 'i',  'v'}
>>> del s2   #删除集合本身 
>>> print(s2)    #NameError: name 's2' is not defined

四、集合类型操作符 

1   in ,not in
2   集合等价与不等价(==, !=)

3   子集、超集
s=set('alvinyuan')
s1=set('alvin')
print('v' in s)
print(s1<s)

4   联合(|)
联合(union)操作与集合的or操作其实等价的,联合符号有个等价的方法,union()。
s1=set('alvin')
s2=set('yuan')
s3=s1|s2
print(s3)  #{'a', 'l', 'i', 'n', 'y', 'v', 'u'}
print(s1.union(s2)) #{'a', 'l', 'i', 'n', 'y', 'v', 'u'} 

5、交集(&)
与集合and等价,交集符号的等价方法是intersection()
s1=set('alvin')
s2=set('yuan')
s3=s1&s2
print(s3)  #{'n', 'a'}

print(s1.intersection(s2)) #{'n', 'a'}

6、查集(-)
等价方法是difference()
s1=set('alvin')
s2=set('yuan')
s3=s1-s2
print(s3)  #{'v', 'i', 'l'}

print(s1.difference(s2)) #{'v', 'i', 'l'} 

7、对称差集(^)
对称差分是集合的XOR(‘异或’),取得的元素属于s1,s2但不同时属于s1和s2.其等价方法symmetric_difference()
s1=set('alvin')
s2=set('yuan')
s3=s1^s2
print(s3)  #{'l', 'v', 'y', 'u', 'i'}

print(s1.symmetric_difference(s2)) #{'l', 'v', 'y', 'u', 'i'}

应用

'''最简单的去重方式'''
lis = [1,2,3,4,1,2,3,4]
print list(set(lis))    #[1, 2, 3, 4]


















本文转自lb沫51CTO博客,原文链接:http://blog.51cto.com/13562606/2059654,如需转载请自行联系原作者
相关文章
|
4天前
|
Java 程序员 C语言
赶快收藏!全网最佳Set集合详解:HashSet、TreeSet!
面试官:那TreeSet要怎么定制排序?TreeSet的自定义排序我们要利用Comparator接口,通过向TreeSet传入自定义排序规则的Comparator来实现。官方源码是这么解释的,南友们看一看。// 构造一个新的空树集,根据指定的比较器进行排序。// 插入到集合中的所有元素都必须能够通过指定的比较器相互比较: comparator. compare(e1, e2)不得对集合中的任何元素e1和e2抛出ClassCastException。
赶快收藏!全网最佳Set集合详解:HashSet、TreeSet!
|
5天前
|
存储 安全 Java
java集合框架复习----(4)Map、List、set
这篇文章是Java集合框架的复习总结,重点介绍了Map集合的特点和HashMap的使用,以及Collections工具类的使用示例,同时回顾了List、Set和Map集合的概念和特点,以及Collection工具类的作用。
java集合框架复习----(4)Map、List、set
|
3天前
|
算法 数据处理 Python
Python中的集合的运算
Python中的集合的运算
|
5天前
|
存储 Java
java集合框架复习----(3)Set
这篇文章详细介绍了Java集合框架中的Set集合,包括HashSet和TreeSet的特点、实现原理和使用示例,展示了Set集合的无序性、元素唯一性以及如何通过自定义比较器实现元素的排序。
|
16天前
|
Python
python集合类型 (Set Types)
【8月更文挑战第3天】
38 9
|
13天前
|
Python
【Leetcode刷题Python】剑指 Offer II 082. 含有重复元素集合的组合
解决LeetCode平台《剑指 Offer II 082. 含有重复元素集合的组合》题目的Python代码实现,通过深度优先搜索算法找出所有和为特定目标值的数字组合,并在搜索过程中通过排序和跳过重复元素来避免解集中出现重复组合。
22 2
|
21天前
|
算法 Python
Python实现求多个集合之间并集的方法
Python实现求多个集合之间并集的方法
10 0
Python实现求多个集合之间并集的方法
|
6天前
|
SQL 机器学习/深度学习 算法
【python】python指南(八):静态类型注解之Set
【python】python指南(八):静态类型注解之Set
12 0
|
10天前
|
存储 Python
Python字典与集合
【8月更文挑战第9天】本文深入探讨了Python中字典和集合这两种重要数据结构的使用方法。字典采用键值对形式存储数据,支持创建、添加、删除及检索等操作;集合则存储唯一元素,适用于成员检测等场景。文中通过丰富的代码示例介绍了如何利用这两种数据结构,并展示了字典推导式、集合推导式等高级技巧,帮助读者更高效地处理数据。阅读本文后,你将能够更加熟练地运用字典和集合解决实际问题。
23 0
|
17天前
|
Python
【Python 3】Set集合的解析与使用
文章介绍了Python中Set集合的用法,包括如何创建集合、添加和删除元素,以及如何进行元素计数和成员资格检查。
9 0