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() | 返回集合的所有元素之和 |
以上差不多就是集合内容了,下面接着就是字典了!