Python之路-基础数据类型之字典 集合
字典的定义-dict
字典的操作
增
dic = {1:'好',2:'美',3:'啊'} dic[4] = '哈哈' # 4这个key值不存在,所以新增 print(dic) 输出结果:{1: '好', 2: '美', 3: '啊', 4: '哈哈'} dic[4] = '你笑啥' # 4这个key值存在,所以修改 print(dic) 输出结果:{1: '好', 2: '美', 3: '啊', 4: '你笑啥'}
dic = {1:'好',2:'美',3:'啊'} dic.setdefault(4) print(dic) 返回结果:{1: '好', 2: '美', 3: '啊', 4: None} dic = {1:'好',2:'美',3:'啊'} dic.setdefault(4,'hahh') print(dic) 返回结果:{1: '好', 2: '美', 3: '啊', 4: 'hahh'}
dic = {} lst = ['hello','world'] dic = dic.fromkeys(lst,[1,2,3,4]) print(dic) dic['hello'].append(5) print(dic) 输出结果: #列表是可变的,所以在输出的结果中都发生了变化 {'hello': [1, 2, 3, 4], 'world': [1, 2, 3, 4]} {'hello': [1, 2, 3, 4, 5], 'world': [1, 2, 3, 4, 5]} dic = {} lst = ['hello','world'] dic = dic.fromkeys(lst,'he') print(dic) dic['hello'] = dic['hello'] + 'l' print(dic) 输出结果: {'hello': 'he', 'world': 'he'} {'hello': 'hel', 'world': 'he'}
删
dic = {1:'好',2:'美',3:'啊'} print(dic.pop(2))# 可返回删除的值 print(dic.pop(5,"找不到呀"))#找不到时会报错,可在括弧第二个区域输入提示语句
改
dic = {1:'好',2:'美',3:'啊'} dic1 = {1:'不好',5:'哈哈'} dic.update(dic1)#根据括弧里面的修改,若有就改,没有就新增 print(dic) 运行结果:{1: '不好', 2: '美', 3: '啊', 5: '哈哈'}
查
dic = {1:'好',2:'美',3:'啊'} print(dic.get(3)) print(dic.get(5,'没有啊'))# 若不存在则返回None,可添加提示语 运行结果: 啊 没有啊
字典的其他操作
dic = {1:'好',2:'美',3:'啊'} print(dic.keys()) #高仿列表 结果是元组 print(dic.values()) #高仿列表 结果是元组 print(dic.items()) #元组形式 不能使用下标 输出结果: dict_keys([1, 2, 3]) dict_values(['好', '美', '啊']) dict_items([(1, '好'), (2, '美'), (3, '啊')])
字典的嵌套
不再详述
集合的定义-set
集合的操作
增
se = {0,1,2,'h','lol',(1,2)} se.add(3) print(se) 运行结果:{0, 1, 2, (1, 2), 3, 'lol', 'h'}
se = {1,2,'ha','lal',4} msg = '你好啊' se.update(msg)#迭代更新,跟dic.fromlkeys()有点像 print(se) 运行结果:{1, 2, '你', 4, '好', '啊', 'lal', 'ha'}
删
se = {1,2,'ha','lal',0,4} se.pop() print(se) 运行结果:{1, 2, 4, 'lal', 'ha'}
se = {1,2,'ha','lal',0,4} se.remove(1) print(se) 运行结果:{0, 2, 4, 'ha', 'lal'}
集合的其他操作
交集
se = {1,2,'ha','lal',0,4} se1 = {1,3,'ha','lal',0,4} print(se & se1) print(se.intersection(se1))
并集
se = {1,2,'ha','lal',0,4} se1 = {1,3,'ha','lal',0,4} print(se | se1) print(se.union(se1))
差集
se = {1,2,'ha','lal',0,4} se1 = {1,3,'ha','lal',0,4} print(se - se1) print(se.difference(se1)) 输出结果:{2}
反交集
se = {1,2,'ha','lal',0,4} se1 = {1,3,'ha','lal',0,4} print(se ^ se1) print(se.symmetric_difference(se1)) 运行结果:{2, 3}
子集
se = {1,2,'ha','lal',0,4} se1 = {1,3,'ha','lal',0,4} print(se < se1) print(se.issubset(se1)) 运行结果:False
超级
se = {1,2,'ha','lal',0,4} se1 = {1,3,'ha','lal',0,4} print(se > se1) print(se.issuperset(se1)) 运行结果:False
forzenset(可迭代对象)
se = {1,2,'ha','lal',0,4} lst = [1,2,3,4] dic = {1:'hao',2:'buhao'} se1 = frozenset(se) lst1 = frozenset(lst) dic1 = frozenset(dic) print(se1) print(lst1) print(dic1) 运行结果: frozenset({0, 1, 2, 'ha', 4, 'lal'}) frozenset({1, 2, 3, 4}) frozenset({1, 2})
Python之路-基础数据类型之字典 集合的更多相关文章
- 百万年薪python之路 -- 基础数据类型的补充
基础数据类型的补充 str: 首字母大写 name = 'alexdasx' new_name = name.capitalize() print(new_name) 通过元素查找下标 从左到右 只查 ...
- Python之路-基础数据类型之列表 元组
列表的定义 列表是Python基础数据类型之一,它是以[ ]括起来, 每个元素用' , '隔开而且可以存放各种数据类型: lst = [1,2,'你好','num'] 列表的索引和切片 与字符串类似, ...
- 百万年薪python之路 -- 基础数据类型的补充练习
1.看代码写结果 v1 = [1,2,3,4,5] v2 = [v1,v1,v1] v1.append(6) print(v1) print(v2) [1,2,3,4,5,6] [[1,2,3,4,5 ...
- python之路--基础数据类型的补充与深浅copy
一 . join的用法 lst =['吴彦祖','谢霆锋','刘德华'] s = '_'.join(lst) print(s) # 吴彦祖_谢霆锋_刘德华 # join() "*" ...
- Python之路-基础数据类型之字符串
字符串类型 字符串是不可变的数据类型 索引(下标) 我们在日常生活中会遇到很多类似的情况,例如吃饭排队叫号,在学校时会有学号,工作时会有工号,这些就是一种能保证唯一准确的手段,在计算机中也是一样,它就 ...
- Python基础数据类型之字典
基础数据类型之字典 ps:数据类型划分:可变数据类型和不可变数据类型. 不可变数据类型:元组(tupe).布尔值(bool).整数型(int).字符串(str).不可变数据类型也称为可哈希. 可变 ...
- Python入门篇-基础数据类型之整型(int),字符串(str),字节(bytes),列表(list)和切片(slice)
Python入门篇-基础数据类型之整型(int),字符串(str),字节(bytes),列表(list)和切片(slice) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.Py ...
- Python基础学习Day7 基础数据类型的扩展 集合 深浅copy
一.基础数据类型的扩展 1.1GBK ---> UTF - 8 # str --->bytes s1 = '太白' # 字符串是unicode编码 b1 = s1.encode('gbk' ...
- python变量与基础数据类型
一.什么是变量 变量是什么? 变量:把程序运行的中间结果临时的存在内存里,以便后续的代码调用.在python中一切都是变量. 1.python变量命名的要求 1,必须有数字,字母,下划线任意组合. ...
随机推荐
- 自己写的Grid组件,第二版
大体没什么变化,主要是添加了一个方法,getSelectedItems(),返回当前选中的数据项. (function ($) { $.fn.GridView = function (setting) ...
- dubbo与springboot的三种整合方式
SpringBoot与dubbo整合的三种方式:1.导入dubbo-starter,在application.properties配置属性,使用@Service暴露服务,使用@Reference引用服 ...
- html5拖动滑块
html5中input有增加type=range.这为拖动滑块提供了很大的便利.下面是他的属性: <!DOCTYPE html> <html lang="en"& ...
- apache配置优化 - 解决apache环境下网站访问速度慢的问题(重点参考)
如果apche访问量过大,将会导致页面打开迟缓,下载速度也降低,如果由于经费和环境问题,集群方案没有得以应用.可以通过对Apache2增加模块MPM来进行优化, 这里我选择线程型MPM加以优化: 开 ...
- JDK原子类操作
JDK原子类操作及原理 在JDK5之后,JDK提供了对变量的原子类操作, java.util.concurrent.atomic里都是原子类 原子类的分类 原子更新基本类型 原子更新数组 原子更新抽象 ...
- js AES对称加密 16进制和base64格式
<!doctype html> <html> <head> <meta charset="utf-8"> <title> ...
- 实现如下语法的功能:var a = add(2)(3)(4)
function add(num){ var _add = function(args){ num+=args; return arguments.callee; } _add.toString = ...
- DrawerLayout Demo
源码下载:http://download.csdn.net/detail/bx276626237/8882763
- java 序列化Serializable 详解
Java 序列化Serializable详解(附详细例子) 1.什么是序列化和反序列化Serialization(序列化)是一种将对象以一连串的字节描述的过程:反序列化deserialization是 ...
- COGS 1144. [尼伯龙根之歌] 精灵魔法
★ 输入文件:alfheim.in 输出文件:alfheim.out 简单对比时间限制:1 s 内存限制:128 MB [题目背景] 『谜题在丛林中散发芳香绿叶上露珠跳跃着歌唱火焰在隐 ...