沐枫凌-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)--字典

猜你喜欢

转载自blog.csdn.net/weixin_42582160/article/details/81005892
7-3