set集合的特点是无序、不重复序列

创建集合:

1
2
3
4
5
6
7
8
9
10
11
12
13
a.s1 = {11,22}
b.s2 = set()
c.s3 = set([11,22,33,44])
s = set()   #创建空集合
li = [11,22,11,22]
s2 = set(li)
print(s2)
{11, 22}
se = {"123","456"}
li = [ ]
list((11,22,33,44))
原理:当执行list()时,内部会调用list __init__,内部执行for循环(11,22,33,44) [11,22,33,44]
#只要类()这样的形式,就会去调用__init__的方法。

操作集合:

 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
s = set()
s.add(123)   #添加元素
s.add(123)
s.add(123)
print(s)
s.clear()    #清空内容
s.copy()     #浅拷贝
s1 = {11,22,33}
s2 = {22,33,44}
s3 = s1.difference(s2)   #a中存在,b中不存在的 s1中存在,s2中不存在
s4 = s2.difference(s1)   #s2中存在,s1中不存在
# s3 = s1.symmetric_difference(s2)   #a中存在b中不存在,b中存在a中不存在的拿出来。
# print(s3)
# s1.difference_update(s2)            #把a(s1)中存在,b(s2)中不存在的值更新到a中。如果以后还会用到s1,就不要用此方法,如果确定以后不会再用
# s1了就可以直接用这个方法。这样的好处是减少变量的声明。
# print(s1)
# s1.discard(11)       #移除指定元素,如果元素不存在则不报错
# s1.remove(1111)      #移除指定元素,如果元素不存在则报错
# s1.pop()             #随机移除一个s1中的元素,因为集合是无序的,所以移除元素是不确定的。移除的
# 时候会返回移除的元素的值。
# pop方法演示:
s1 = {11,22,33}
ret = s1.pop()
print(ret)
33
 
# s1 = {11,22,33}
# s2 = {22,33,44}
# s3 = s1.intersection(s2)   #取s1和s2的交集,就是两个集合都有的元素
# print(s3)
# {33, 22}
# s1.intersection_update(s2)  #同样与difference_update类似,把两个集合的交集元素更新到s1中
# print(s1)
# s3 = s1.union(s2)     #把两个集合合起来,去并集。如s1和s2,结果就是11,22,33,44
# print(s3)
# {33, 22, 11, 44}
s1 = {11,22,33}
s1.update([55,66,777])            #接收一个可迭代的对象,内部会自己去循环这个对象,然后把元素
# 更新到集合中。相当于批量添加
print(s1)
{33, 66, 777, 11, 22, 55}
s1.update("abcdefg")              #字符串也是可迭代的,会把每个字符分开,更新到集合中
print(s1)
set练习题:
假设脚本自动采集资产。当前情况是:1槽:8G 2槽:4G 4槽2G,如果你做了一个操作,将4槽的内存放到了3槽,1槽的内存换成了4G。资产更新了,应该把最新的数据更新到字典中。
1
2
3
4
5
6
7
8
9
10
11
old_dict = {
    "#1": 8,
    "#2": 4,
    "#4": 2,
}
 
new_dict = {
    "#1": 4,
    "#2": 4,
    "#3": 2,
}
现在应该把#3的数据更新到old_dic字典中,把#4的数据删除,然后更新#1的值。
首先要找出:
应该删除哪几个槽位
应该更新哪几个槽位
应该增加那几个槽位
1
2
3
del_set = set(old_dict).difference(set(new_dict))      #取出需要删除的槽位{'#4'}
add_set = set(new_dict).difference(set(old_dict))      #取出需要添加的槽位{'#3'}
update_set = set(new_dict).intersection(set(old_dict)) #取出需要更新的槽位{'#2', '#1'}

python(三)set集合的更多相关文章

  1. Python之路(第五篇) Python基本数据类型集合、格式化、函数

    一.变量总结 1.1 变量定义 记录某种状态或者数值,并用某个名称代表这个数值或状态. 1.2 变量在内存中的表现形式 Python 中一切皆为对象,数字是对象,列表是对象,函数也是对象,任何东西都是 ...

  2. Python的set集合详解

    Python 还包含了一个数据类型 -- set (集合).集合是一个无序不重复元素的集.基本功能包括关系测试和消除重复元素.集合对象还支持 union(联合),intersection(交),dif ...

  3. Python基本数据类型集合、格式化、函数

    一.变量总结 1.1 变量定义 记录某种状态或者数值,并用某个名称代表这个数值或状态. 1.2 变量在内存中的表现形式 Python 中一切皆为对象,数字是对象,列表是对象,函数也是对象,任何东西都是 ...

  4. Python - 三大器 迭代器,生层器,装饰器

    目录 Python - 三大器 迭代器,生层器,装饰器 一. 容器 二. 可迭代对象(iterable) 三. 迭代器 四. 生成器 五. 装饰器 1. 定义 六. 闭包 Python - 三大器 迭 ...

  5. Python列表、集合与字典(3)

    目录 一.列表 二.集合 三.字典 一.列表 1. 列表初识   列表的使用为处理特定顺序排列的数据提供了便利,列表元素可以是字母.数字或者其他信息,同时所加元素之间不存在任何关系.   在Pytho ...

  6. python基本数据类型集合set操作

    转:https://www.cnblogs.com/tina-python/p/5468495.html 一.集合的定义 set集合,是一个无序且不重复的元素集合. 集合对象是一组无序排列的可哈希的值 ...

  7. python基础数据类型--集合(set)

    python基础数据类型--集合(set) 集合是一个数学概念由一个或多个确定的元素所构成的整体叫做集合 集合中的三个特征 1.确定性(元素必须死可hash) 2.互异性(去重) 3.无序性(集合中的 ...

  8. JAVA:三种集合LIST、SET、MAP

    1. 集合框架介绍 我 们知道,计算机的优势在于处理大量的数据,在编程开发中,为处理大量的数据,必须具备相应的存储结构,数组可以用来存储并处理大量类型相同的数 据,但是会发现数组在应用中的限制:数组长 ...

  9. python爬虫工具集合

    python爬虫工具集合 大家一起来整理吧!强烈建议PR.这是初稿,总是有很多问题,而且考虑不全面,希望大家支持! 源文件 主要针对python3 常用库 urllib Urllib是python提供 ...

随机推荐

  1. layoutSubviews #pragma mark -

    >>>layoutSubviews: layoutSubviews是对sbuviews的重新布局,比如,我们想更新子视图的位置,可以通过调用layoutSubviews方法(不能直接 ...

  2. 20145337《JAVA程序设计》第一周学习总结

    # 20145337 <Java程序设计>第1周学习总结 ## 教材学习内容总结 第一章 -Java最早是Sun公司撰写Star7应用程序的程序语言 -根据应用领域不同,有Java SE. ...

  3. C++产生随机数四则运算

    产生两位随机整数,随机四则运算符,生成30道运算题. 一.编程思路 看到要求,首先想到的是怎么运用随机数,因为自己对随机数的不熟练所以还要在查很多东西.在一个for循环内先产生两个30以内的随机数,在 ...

  4. Windows内核 内存管理基本概念

    内存管理概念: 1)物理内存 PC上有三条总线:数据总线.地址总线和控制总线.32位CPU的寻址能力是4GB个字节,用户最多可以使用4GB的真实物理内存.PC中很多设备都提供了自己的设备内存,例如显卡 ...

  5. 使用beanUtils操纵javabean

    Sun公司的内省API过于繁琐,所以Apache组织结合很多实际开发中的应用场景开发了一套简单.易用的API操作Bean的属性——BeanUtils,在Beanutil中可以直接进行类型的自动转换. ...

  6. linux下缓存的查看/修改

    起因: 安装openstack过程中内存不够大,提高内存后想起缓存一般设置为内存的两倍. 缓存的实质是硬盘开辟一个空间,然后设置这个空间为缓存. 查看缓存大小 free -m free -m tota ...

  7. 导入TDP数据包备份

    package org.alfresco.repo.bom.util; import java.io.BufferedReader; import java.io.File; import java. ...

  8. mysql重点--执行计划

    explain SQL: 在sql语句前面加explain实现"执行计划"的功能.功能是比较准确的显示将要执行这条sql语句的运行状况. select_simple 是查询类型:t ...

  9. 录制简单的自动化测试工具SlikMobile初体验

    今天朋友推荐了款自动化测试工具SlikMobile,下载了个试用了下,感觉还是很容易入门和上手的,感觉和testin的工具差不多,跨平台,多语言支持,支持图片.文本和Native Class三种对象方 ...

  10. Windwos服务器远程桌面不能复制粘贴的解决方法

    今天使用远程桌面连接登陆服务器,发现不能在本地电脑和远程服务器之间复制粘贴文件了,复制粘贴文本也不行. 网上搜了一下,主要有两种情况: 1.复制粘贴功能原本可以用,突然失灵了2.从头到尾都无法使用这个 ...