python集合总结
知识点
- python语言提供的内置数据结构
- 与列表和字典一样都属于可变类型的序列
- 集合是没有value的字典 。如下:
- 字典 {‘hello’:56,‘world’:78}
- 集合{‘hello’,'world '}
集合的创建
'''第一种创建方式使用{}'''
s={2,3,4,5,6,7,7}
print(s)
'''第二种创建方式set()'''
s=set(range(6))
print(s,type(s))
print('-----------其他类型的数据转成集合-----------')
s1=set([1,2,3,4,5,5,5,6,6])
print(s1,type(s1))
s2=set((1,2,3,4,5,5,66))
print(s2,type(s2))
s3=set('helloworld')
print(s3,type(s3))
s4=set({23,45,5,54,34})
print(s4,type(s4))
print('-----定义空集合--------')
s6={}
print(s6,type(s6))
s7=set()
print(type(s7))
运行结果:
{2, 3, 4, 5, 6, 7}
{0, 1, 2, 3, 4, 5} <class 'set'>
-----------其他类型的数据转成集合-----------
{1, 2, 3, 4, 5, 6} <class 'set'>
{1, 2, 3, 4, 5, 66} <class 'set'>
{'o', 'w', 'e', 'l', 'r', 'h', 'd'} <class 'set'>
{34, 5, 54, 23, 45} <class 'set'>
-----定义空集合--------
{} <class 'dict'>
<class 'set'>
集合的增删操作
print('-------集合的增删--------')
s={10,20,30,40,50}
s.add(80)
print(s)
s.update({200,100,34})
print(s)
s.update((99,88,22))
print(s)
s.remove(99)
print(s)
'''s.remove(8888) #KeyError: 8888如果元素不存在报错
print(s)'''
s.discard(9999)
print(s)
s.pop()
print(s)
s.clear()
print(s)
-------集合的增删--------
{80, 50, 20, 40, 10, 30}
{34, 100, 40, 200, 10, 80, 50, 20, 30}
{34, 99, 100, 40, 200, 10, 80, 50, 20, 22, 88, 30}
{34, 100, 40, 200, 10, 80, 50, 20, 22, 88, 30}
{34, 100, 40, 200, 10, 80, 50, 20, 22, 88, 30}
{100, 40, 200, 10, 80, 50, 20, 22, 88, 30}
set()
集合间的关系
s1={10,20,30,40}
s2={20,30,10,40}
print(s1==s2)
print(s1!=s2)
'''一个集合是否是另一个集合的子集'''
s1={10,20,30,40,50,60}
s2={10,20,30,40,50}
s3={10,20,30,40}
print(s2.issubset(s1))
print(s3.issubset(s1))
'''一个集合是否是另一个集合的超集'''
print(s1.issuperset(s2))
print(s1.issuperset(s3))
'''判断一个集合和另一个集合是否没有交集'''
print(s2.isdisjoint(s3))
运行结果:
True
False
True
True
True
True
False
集合的数学操作+生成式
print('---------集合的数学操作--------')
s1={10,20,30,40}
s2={20,30,40,50,60}
print(s1.intersection(s2))
print(s1 & s2)
print(s1.union(s2))
print(s1 | s2)
print(s1.difference(s2))
print(s1-s2)
print(s1.symmetric_difference(s2))
print(s1^s2)
print('-------集合生成式---------')
s={i*i for i in range(10)}
print(s)
---------集合的数学操作--------
{40, 20, 30}
{40, 20, 30}
{40, 10, 50, 20, 60, 30}
{40, 10, 50, 20, 60, 30}
{10}
{10}
{50, 10, 60}
{50, 10, 60}
-------集合生成式---------
{0, 1, 64, 4, 36, 9, 16, 49, 81, 25}
列表、字典、元组、集合总结
数据结构 | 是否可变 | 是否重复 | 是否有序 | 定义符号 |
---|
列表(list) | 是 | 可重复 | 有序 | [ ] |
元组(tuple) | 否 | 可重复 | 有序 | ( ) |
字典(dict) | 是 | key不可,value可 | 无序 | {key:value} |
集合(set) | 是 | 不可重复 | 无序 | { } |