沐枫凌-python 新手教学(7-3)--集合

python里的集合和高中所讲的集合差不都一个意思,所编写的格式也 差不多

那么现在来为大家讲讲  集合Sets  吧

集合什么样?

集合就下面样,里面的元素可以是任何合法的东西

{1,2,3,4}
{'asd','asdff','1d-a'}

集合在囊括元素的时候遵守了类似于数学上的规则,那就是<无序性>,<不可重复性>

<不可重复性>:也就是说一个集合里面不能同时拥有多个相同的元素,在编写的时候要是写了两个相同的元素的话,程序会自动消为一个

<无序性>:也就是没有顺序,你不能像列表(List)或元组(Tuple)那样来提取元素或对其切片

创建集合

创建集合可以直接  变量 = {xxx,yyy,zzz}(!!但是不能 变量 = {} 这样是创建一个空的字典!!!)

或者是set('asdfas')==>{'a','s','d','f'}

集合的运算

拥有和数学一样的运算方式(交集,并集,子集等)

求以自身为全集,与另一个集合的交集的的补集(SetsA-SetsB)

a = {1,2,3,4,5}
b = {3,4,5,6,7,8}
print(b-a)

结果是

{8, 6, 7}

求并集(SetsA|SetsB)

 

 

 

a = {1,2,3,4,5}
b = {3,4,5,6,7,8}
print(a|b)

结果是

{1, 2, 3, 4, 5, 6, 7, 8}

求交集(SetsA&SetsB)

a = {1,2,3,4,5}
b = {3,4,5,6,7,8}
print(a&b)

结果是

{3, 4, 5}

以两集合并集为全集,求两集合交集的补集

a = {1,2,3,4,5}
b = {3,4,5,6,7,8}
print(a^b)

结果是

{1, 2, 6, 7, 8}

!!!集合之间没有  +加运算 也就是说不能 {xxx}+{yyy}

 

判定集合内元素的存在

 

a = {1,2,3,4,5,6}
print(1 in a)

结果是True

判定子集的存在(SetsA<SetsB or SetsA>SetsB)

a = {1,2,3,4,5}
b = {1,2,3,4}
print(a<b)
print(a>b)

结果为

False
True

集合的变换方法总括

 

set.add()将元素添加到集合中
set.clear()删除集合中的所有元素
set.copy()返回集合的浅拷贝
set.difference()将两个或多个集合的差集作为一个新集合返回
set.difference_update()从这个集合中删除另一个集合的所有元素
set.discard()删除集合中的一个元素(如果元素不存在,则不执行任何操作)
set.intersection()将两个集合的交集作为一个新集合返回
set.intersection_update()用自己和另一个的交集来更新这个集合
set.isdisjoint()如果两个集合有一个空交集,返回 True
set.issubset()如果另一个集合包含这个集合,返回 True
set.issuperset()如果这个集合包含另一个集合,返回 True
set.pop()删除并返回任意的集合元素(如果集合为空,会引发 KeyError)
set.remove()删除集合中的一个元素(如果元素不存在,会引发 KeyError)
set.symmetric_difference()将两个集合的对称差作为一个新集合返回
set.symmetric_difference_update()用自己和另一个的对称差来更新这个集合
set.union()将集合的并集作为一个新集合返回
set.update()用自己和另一个的并集来更新这个集合

集合的内置函数

 

set.all()如果集合中的所有元素都是 True(或者集合为空),则返回 True。
set.any()如果集合中的所有元素都是 True,则返回 True;如果集合为空,则返回 False。
set.enumerate()返回一个枚举对象,其中包含了集合中所有元素的索引和值(配对)。
set.len()返回集合的长度(元素个数)
set.max()返回集合中的最大项
set.min()返回集合中的最小项
set.sorted()从集合中的元素返回新的排序列表(不排序集合本身)
set.sum()返回集合的所有元素之和

以上差不多就是集合内容了,下面接着就是字典了!

沐枫凌-python 新手教学(7-4)--字典

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值