初识Python第三天(一)
一.set集合
set是一个无序且不重复的元素集合
- print(dir(set))
- #['__and__', '__class__', '__contains__', '__delattr__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__gt__', '__hash__', '__iand__', '__init__', '__init_subclass__', '__ior__', '__isub__', '__iter__', '__ixor__', '__le__', '__len__', '__lt__', '__ne__', '__new__', '__or__', '__rand__', '__reduce__', '__reduce_ex__', '__repr__', '__ror__', '__rsub__', '__rxor__', '__setattr__', '__sizeof__', '__str__', '__sub__', '__subclasshook__', '__xor__', 'add', 'clear', 'copy', 'difference', 'difference_update', 'discard', 'intersection', 'intersection_update', 'isdisjoint', 'issubset', 'issuperset', 'pop', 'remove', 'symmetric_difference', 'symmetric_difference_update', 'union', 'update']
- l1 = ['', '', '',]
- l2 = ['', '', '', ]
- s1 = set(l1) #将一组可迭代的数据传入set集合
- print(s1)
- s1.add('alex') #给s1添加一个新元素alex,
- print(s1)
- s1.add('alex') #给s1传入一个相同的元素后,对比输出结果二和三,结果并没有改变,由此可见s1集合是一个无序且不重复的元素集合
- print(s1)
- #{'11', '33', '22'} #第一次输出
- #{'11', '33', '22', 'alex'} #第二次输出
- #{'11', '33', '22', 'alex'} #第三次输出
add 添加不重复的元素
- #difference生成一个新的集合,将新传入的集合移除掉,不能对原来的集合进行修改,需要重新赋值给一个变量
- s2 = set(['alex', 'eric', 'tony', ])
- s3 = s2.difference(['alex', 'eric'])
- print(s3)
- #结果输出 {'tony'}
difference 差异比较
- s2 = set(['alex', 'eric', 'tony', 'alex'])
- s4 = s2.difference_update(['alex', 'eric','jack'])
- print(s2) #结果输出 {'tony'}
- print(s4) #结果输出 None
- #difference_update将原来的集合修改,difference_update和difference都是将新传入的集合删掉,不同之处在于difference是生成一个新的集合,difference_update是对原来的集合进行修改,不会生成一个新的集合
difference_update 差异更新
- s2 = set(['alex', 'eric', 'tony',])
- s3 = s2.discard('eric')
- print(s2)
- #结果输出{'tony', 'alex'}
discard删除一个元素
- #pop随机删除一个元素,并获取删除的这个元素,可将删除的这个元素赋值给变量
- s2 = set(['alex', 'eric', 'tony',])
- ret = s2.pop()
- print(s2) #结果输出{'alex', 'eric'}
- print(ret) #从新赋值给变量ret ,结果输出 tony
pop 随机删除元素
- #remove移除元素,需要指定参数,remove没有返回值
- s2 = set(['alex', 'eric', 'tony',])
- s2.remove('eric')
- print(s2) #结果输出 {'alex', 'tony'}
remove移除指定元素
- l1 = ['alex', 'eric', 'jack', 'laiying',]
- l2 = ['jack', 'tom', 'laiying',]
- s1 = set(l1)
- s2 = set(l2)
- print(s1)
- s3 = s1.intersection(s2)
- print(s1)
- print(s2)
- print(s3)
- #{'eric', 'alex', 'laiying', 'jack'} 第一次原始集合
- #{'eric', 'alex', 'laiying', 'jack'} 集合s1和s2进行交集判断后的输出结果,并没有改变对象本身
- #{'laiying', 'tom', 'jack'} s2集合没有发送改变
- #{'laiying', 'jack'} 通过交集比较,返回了一个新的元素集合,返回的是s1和s2共同拥有的元素集合
intersection取交集元素集合
- l1 = ['alex', 'eric', 'jack', 'laiying',]
- l2 = ['jack', 'tom', 'laiying',]
- s1 = set(l1)
- s2 = set(l2)
- print(s1)
- s3 = s1.intersection_update(s2)
- print(s1)
- print(s3)
- #通过输出结果可以看出,s1直接更新了自己,把与传入的集合,与集合里面不相同的元素删掉,且没有返回值
- {'laiying', 'eric', 'alex', 'jack'}
- {'laiying', 'jack'}
- None
indersection_update 交集更新
- l1 = ['alex', 'eric',]
- l2 = ['tom', 'jack',]
- s1 = set(l1)
- s2 = set(l2)
- print(s1)
- s3 = s1.isdisjoint(s2)
- print(s1)
- print(s3)
- #{'eric', 'alex'}
- #{'eric', 'alex'}
- #True
- #当两个集合之间没有任何交集时,就返回True,否则就返回False
isdisjoint判断是否没有交集
- l1 = ['alex', 'eric', 'jack',]
- l2 = ['tom','laiying',]
- s1 = set(l1)
- s2 = set(l2)
- s3 = set(['alex', 'jack',])
- print(s1.issubset(s2)) #输出为False说明s1不是s2的子集
- print(s1.issubset(s3)) #输出False说明不是s3的子集
- print(s3.isdisjoint(s1)) #输出True说明s3是s1的子集
- #结果输出
- #False
- #False
- #True
issubset 是否是子集
- l1 = ['alex', 'eric', 'jack',]
- l2 = ['tom','laiying',]
- s1 = set(l1)
- s2 = set(l2)
- s3 = set(['alex', 'jack',])
- print(s1.issuperset(s3)) #结果输出True,说明s1是s3的父集
- print(s3.issuperset(s1)) #结果输出False,说明s3不是s1的父集
issuperset是否是父集
- #symmetric_difference,该对象返回一个新的集合,传入的元素与对象本身比较,如果传入的元素里面有的元素,而对象本身没有,则添加到对象本身集合内,最终返回一个新的集合
- l1 = ['alex', 'eric', 'jack',]
- l2 = ['tom','laiying',]
- s1 = set(l1)
- s2 = set(l2)
- s3 = set(['alex', 'jack',])
- print(s1)
- #结果输出 {'eric', 'alex', 'jack'}
- s4 = s1.symmetric_difference(s2)
- print(s1)
- #结果输出 {'eric', 'alex', 'jack'}
- print(s4)
- #结果输出{'eric', 'alex', 'tom', 'laiying', 'jack'}
symmetric_difference 差集对比
- #symmetric_difference_update差集更新,直接扩展对象本身与传入集合的没有交集的元素
- l1 = ['alex', 'eric', 'jack',]
- l2 = ['tom','laiying',]
- s1 = set(l1)
- s2 = set(l2)
- print(s1) #s1原始集合,结果输出 {'eric', 'alex', 'jack'}
- s4 = s1.symmetric_difference_update(s2)
- print(s1) #s1差集后的结果输出{'laiying', 'eric', 'alex', 'jack', 'tom'}
- print(s4) #该方法没有返回值 None
s1.symmetric_difference_update 差集更新
- #union返回新集合,j将对象本身与传入的集合元素比较,把所有的元素重新组合成一个新的集合返回
- l1 = ['alex', 'eric', 'jack',]
- l2 = ['tom','laiying',]
- s1 = set(l1)
- s2 = set(l2)
- s4 = s1.union(s2)
- print(s1) #结果输出{'eric', 'alex', 'jack'},对象本身没有变化
- print(s4) #结果输出{'laiying', 'jack', 'alex', 'tom', 'eric'}
union 返回新集合
- #update更新集合,将会对集合本身进行扩展,如果对象本身不存在这个传入的元素,则添加到对象本身的元素集合
- dic1 = {'k1':'v1', 'k2':'v2'}
- dic2 = {'k1':'v1', 'k2':'v2', 'k3':'v3'}
- s1 = set(dic1)
- print(s1) #结果输出{'k1', 'k2'}
- s2 = s1.update(dic2)
- print(s1) #结果输出 {'k3', 'k1', 'k2'}
update更新集合
二.collections
2.1counter计数器
- #创建一个Counter对象
- import collections
- obj = collections.Counter('Hello World !')
- print(obj)
- #结果输出
- #Counter({'l': 3, 'o': 2, ' ': 2, '!': 1, 'd': 1, 'r': 1, 'e': 1, 'W': 1, 'H': 1})
- #Counter会对传入参数所有元素出现的次数
- import collections
- a = collections.Counter('LaiYingaaa')
- print(a)
- #Counter({'a': 4, 'i': 2, 'L': 1, 'Y': 1, 'g': 1, 'n': 1})
- b = a.elements() #该方法返回的是一个迭代器,只能通过循环获取
- print(b)
- for i in a:
- print(i) #打印的是所有不重复的传入参数,也就是计数器对应类似字典的key
- #i
- #a
- #L
- #Y
- #g
- #n
elements 只显示不重复的元素
- import collections
- obj = collections.Counter('Hello World !')
- print(obj)
- ret = obj.most_common(4) #这里仅返回出现次数最多的前4个对象
- print(ret)
- #Counter({'l': 3, ' ': 2, 'o': 2, 'H': 1, 'r': 1, 'd': 1, 'W': 1, 'e': 1, '!': 1})
- #[('l', 3), (' ', 2), ('o', 2), ('H', 1)]
most_common 仅返回出现次数最多的前几个对象
- import collections
- obj = collections.Counter(['', '','']) #创建一个counter对象
- obj.subtract(['eric', '', '']) #使用该属性,可以g更新技术器对象个数,如果原来有这个对象,则会减少这个对象,原来没有这个对象则返回-1,如果减少两次没有的这个对象,则返回-2,一吃类推
- print(obj)
- #Counter({'22': 1, '33': 1, '11': 1})
- #Counter({'33': 1, '22': 1, '11': -1, 'eric': -1})
subtract减少对应的元素
- #update 更新,添加
- import collections
- obj = collections.Counter(['', '',''])
- print(obj)
- obj.update(['eric', '', ''])
- print(obj)
- #Counter({'11': 1, '33': 1, '22': 1})
- #Counter({'11': 3, '33': 1, '22': 1, 'eric': 1})
2.2 OrderedDict 有序字典
- #字典是无序的,排列顺序随时都可以改变
- #有序字典继承了dict所有的属性方法,是针对字典类进行了扩展的一个类,可以将字典转换为有序字典
- import collections
- dic = collections.OrderedDict() #将字典转换为有序字典
- # dic = dict() #字典是无序的,排列顺序随时都可更改
- dic['k1'] = 'v1'
- dic['k2'] = 'v2'
- dic['k3'] = 'v3'
- print(dic)
- #OrderedDict([('k1', 'v1'), ('k2', 'v2'), ('k3', 'v3')]) 当字典转换为有序字典以后,排列顺序就不会改变
初识Python第三天(一)的更多相关文章
- 初识Python(三)
一.作用域 对于变量的作用域,执行声明并在内存中存在,该变量就可以在后续的代码中使用: 外层变量,可以被内层变量使用:内层变量,也可以被外层变量使用: 如下示例: #!/usr/bin/env pyt ...
- 初识Python第三天(二)
2.2 OrderedDict有序字典 import collections dic = collections.OrderedDict() dic['k1'] = 'v1' dic['k2'] = ...
- 孤荷凌寒自学python第三十八天初识python的线程控制
孤荷凌寒自学python第三十八天初识python的线程控制 (完整学习过程屏幕记录视频地址在文末,手写笔记在文末) 一.线程 在操作系统中存在着很多的可执行的应用程序,每个应用程序启动后,就可以看 ...
- 孤荷凌寒自学python第三十三天python的文件操作初识
孤荷凌寒自学python第三十三天python的文件操作初识 (完整学习过程屏幕记录视频地址在文末,手写笔记在文末) 今天开始自学python的普通 文件操作部分的内容. 一.python的文件打开 ...
- 孤荷凌寒自学python第三天 初识序列
孤荷凌寒自学python第三天 初识序列 (完整学习过程屏幕记录视频地址在文末,手写笔记在文末) Python的序列非常让我着迷,之前学习的其它编程语言中没有非常特别关注过序列这种类型的对象,而pyt ...
- Python导出Excel为Lua/Json/Xml实例教程(一):初识Python
Python导出Excel为Lua/Json/Xml实例教程(一):初识Python 相关链接: Python导出Excel为Lua/Json/Xml实例教程(一):初识Python Python导出 ...
- Python开发【第一篇】:初识Python
初识python 一.python简介 python的创始人为吉多·范罗苏姆(Guido van Rossum).1989年的圣诞节期间,吉多·范罗苏姆为了在阿姆斯特丹打发时间,决心开发一个新的脚本解 ...
- Python开发【第二篇】:初识Python
Python开发[第二篇]:初识Python Python简介 Python前世今生 python的创始人为吉多·范罗苏姆(Guido van Rossum).1989年的圣诞节期间,吉多·范罗苏 ...
- 初识python面向对象
一.初识python面向对象: class Person: #使用class关键字定义一个类 age=0 #类变量(静态变量) def eat(self,food): #定义一个方法 self.age ...
随机推荐
- Android中layout_gravity和gravity的区别
安卓中的 layout_gravity 属性和 gravity属性 有啥区别? LinearLayout有两个非常相似的属性: android:gravity与android:layout_gravi ...
- 【HDU 4747 Mex】线段数
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4747 题意:有一组序列a[i](1<=i<=N), 让你求所有的mex(l,r), mex ...
- 执行JDBC的executeUpdate()方法时,报错:数据类型不一致,应为number,但却为binary
该原因是因为,在拼写update语句的时候将一个number类型的字段的值赋为了null导致的,如果想将一个number类型的字清空,不能使用null,可以使用“”来替代.
- sort将文件的每一行作为一个单位按ASCII码值进行比较
1 sort的工作原理 sort将文件的每一行作为一个单位,相互比较,比较原则是从首字符向后,依次按ASCII码值进行比较,最后将他们按升序输出. [rocrocket@rocrocket progr ...
- 《JAVA开发环境的熟悉》实验报告——20145337
- A trip through the Graphics Pipeline 2011_13 Compute Shaders, UAV, atomic, structured buffer
Welcome back to what’s going to be the last “official” part of this series – I’ll do more GPU-relate ...
- cacti监控apache和nginx的配置
一.监控apache1.下载http://forums.cacti.net/about25227.html&highlight=apachestats2.其中的ss_apache_stats. ...
- wpf 将Style应用到 ListView 中的 ListViewItem 元素
例: 为每个条目元素设置右键菜单 1. 新建右键菜单元素和样式元素 注意: 同时设置样式元素的 TargetType 属性和 x:Key 属性, 将样式元素限定为应用于 ListViewItem 类型 ...
- libgdx 常见问题
libgdx assets file not found Select Run -> Edit Configurations from the menu In the "Working ...
- CSS之border-radius
1.圆角设置 CSS3圆角只需设置一个属性:border-radius(含义是"边框半径").你为这个属性提供一个值,就能同时设置四个圆角的半径.所有合法的CSS度量值都可以使用: ...