python集合总结,集合的增删改查

python集合总结

知识点

  • python语言提供的内置数据结构
  • 与列表和字典一样都属于可变类型的序列
  • 集合是没有value的字典 。如下:
  • 字典 {‘hello’:56,‘world’:78}
  • 集合{‘hello’,'world '}

集合的创建

# 教育机构   舒寒科技有限公司
# 学习者     舒寒拽少
# 学习时间:  2022/1/11 11:02

'''第一种创建方式使用{}'''
s={2,3,4,5,6,7,7} #集合中元素不能重复,跟字典中key值不能重复是一样的
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'>

集合的增删操作

# 教育机构   舒寒科技有限公司
# 学习者     舒寒拽少
# 学习时间:  2022/1/11 18:48
print('-------集合的增删--------')

s={10,20,30,40,50}
#.add一次只能添加一个元素
s.add(80)
print(s)
#.update一次至少添加一个元素
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()      #.pop不能写参数,是随机删除一个元素
print(s)
s.clear()   #.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()

集合间的关系

# 教育机构   舒寒科技有限公司
# 学习者     舒寒拽少
# 学习时间:  2022/1/11 19:00
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))  #False 表示不是没有交集,意思是有交集
运行结果:
True
False
True
True
True
True
False

集合的数学操作+生成式

# 教育机构   舒寒科技有限公司
# 学习者     舒寒拽少
# 学习时间:  2022/1/11 19:19
print('---------集合的数学操作--------')
#(1)交集
s1={10,20,30,40}
s2={20,30,40,50,60}
print(s1.intersection(s2))
print(s1 & s2)

#(2)并集
print(s1.union(s2))
print(s1 | s2)

#(3)差集操作
print(s1.difference(s2))
print(s1-s2)

#(4)对称差集
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)不可重复无序{ }
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值