day05——字典
day05
字典
字典—— dict:
字典无序的,可变的数据类型
用于存储大量数据,字典要比列表快,将数据和数据之间进行关联
lst1 = ['常鑫','李文虎','张宇'] # 姓名
lst2 = [10,80,100] # 分数
print(lst1[0],lst[0])
逗号分隔叫做一个元素
{键 : 值,键 : 值} ——键值对
字典以散列表和哈希表存储
字典的键必须是可哈希的——不可变的数据类型——避免哈希冲突使用了(开放寻址法)
不可哈希的——可变的数据类型:列表
要求唯一——如果有重复的后面的将前面的覆盖
字典的值:可以任意
定义:dic = {}
dic = {"常鑫":10,"李文虎":80,"张宇":100,10:"大黑哥",True:123,(1,2,3):"大煎饼",[1,2]:"meet"}
print(dic)
字典的增加
- dic['10'] = 89 : 暴力添加
dic = {'常鑫':[1,2,3],'李文虎':'89'}
dic['李文虎'] = 99
print(dic)
- dic.setdefault('内容':'内容') :
用李文虎这个键去字典进行查询,如果不存在就执行添加,如果存在就不添加
dic = {'常鑫':[1,2,3],'李文虎':'89'}
dic.setdefault('李文虎':'99')
print(dic)
print(dic.setdefault('李文虎'))
字典的删除
- del dic[键] :通过字典的键删除键值对
dic = {'常鑫':[1,2,3],'李文虎':'89'}
del dic['常鑫']
print(dic)
- dic.pop(键) :通过字典的键删除键值对
也有返回值:返回的是被删除的值
dic = {'常鑫':[1,2,3],'李文虎':'89'}
print(dic.pop('常鑫'))
print(dic)
- dic.clear() :清空
dic = {'常鑫':[1,2,3],'李文虎':'89'}
dic.clear()
print(dic)
字典的改
- dic[键] = 值 : 字典中没有这个键值对,就是添加,有的时候就是修改
dic = {'常鑫':[1,2,3],'李文虎':'89'}
dic['常鑫'] = 'dsb'
print(dic)
- dic.update(字典) :update括号中的级别高于update前面的字典,有一样就更改值,如果没有就添加在后面
dic = {"常鑫":[1,2,3],'李文虎': '89'}
dic1 = {"1":3,"5":9,"李文虎":100}
dic1.update(dic)
print(dic1)
字典的查
- for循环获取的是字典中每个键值对的键
dic = {"常鑫":[1,2,3],'李文虎': '89'}
for i in dic:
print(i)
- dic.get(键):通过键获取值,如果不存在就返回None
dic = {"常鑫":[1,2,3],'李文虎': '89'}
print(dic.get('常鑫'))# 结果是[1,2,3]
dic = {"常鑫":[1,2,3],'李文虎': '89'}
print(dic.get('cx'))# 结果是None
- dic[键] (建议不使用): 通过键获取值,如果不存在就报错
dic = {"常鑫":[1,2,3],'李文虎': '89'}
print(dic['常鑫']) # 结果是[1,2,3]
dic = {"常鑫":[1,2,3],'李文虎': '89'}
print(dic['cx']) # 报错
其他操作
dic = {"1":3,"5":9,"李文虎":100}
for i in dic:
print(i,dic.get(i)) # 获取所有键和值
- dic.keys() : 把键获取到高仿列表里,支持for循环,不支持索引
print(list(dic.keys())) # 获取到列表
dic1 = {"1":3,"5":9,"李文虎":100}
print(dic.keys()) # 结果是:高仿列表—— dic_keys(['1','5','李文虎'])
# 获取字典中所有的键
for i in dic.keys():
print(i)
# 获取字典中所有的值
lst = []
for i in dic:
lst.append(dic[i])
print(lst)
- dic.values() :把值获取到高仿列表里,支持for循环,不支持索引
print(list(dic.values())) # 获取到列表
dic1 = {"1":3,"5":9,"李文虎":100}
# 获取字典中所有的值
print(list(dic.values())) # 结果是[3, 9, 100]
- dic.items() : 把键和值组成的元组获取到高仿列表里,支持for循环,不支持索引
print(list(dic.items())) # 获取到列表
dic1 = {"1":3,"5":9,"李文虎":100}
print(dic.items())
# 结果是dict_items([('1', 3), ('5', 9), ('李文虎', 100)])
# 获取字典的键和值
for i in dic.items():
print(i[0],i[1])
dic1 = {"1":3,"5":9,"李文虎":100}
for i in dic1.items():
print(i)
# 结果是
('1', 3)
('5', 9)
('李文虎', 100)
for k,v in dic1.items():
print(k,v) # 获取每个元素的键和值
# 结果是:
1 3
5 9
李文虎 100
解构
a, b = 10,12
print(a)
print(b)
# 结果是
# 10
# 12
# 面试题
a = 10
b = 20
a,b = b,a
print(a,b) # 结果:20 10
a,b = [1,2]
print(a,b)
# 结果是 1 2
a,b = (3,4)
print(a,b)
# 结果是: 1 2
a,b = "23"
print(a,b) # 结果是: 2 3
工作之后可能会遇见
a,_,b = (3,4,5)
print(a,b) # 等号后边的值和前面的变量名要一一对应
a = 10,12 # 本质就是一个元组
print(a) # 结果是 (10,12)
a,b = {"1":"a","2":"b"} # 得到的是键
print(a,b) # 结果是 1 2
字典的嵌套
通过键一层一层的查找
# dic = {1001:["周杰伦","林俊杰"],
# 1002:{"汪峰":{"前妻1":["大烧饼"],"前妻2":["熊大","熊二"],"国际章":"肉丝"}},
# 1003:{"陈冠希":["阿娇","阿萨","张柏芝"]},
# 1004:{"韦小宝":[{"教主夫人":["教主"]},
# {"阿珂":"刺客"},
# {"双儿":"天地会"},
# {"爱心觉罗建宁":"公主"},
# {"独臂神尼":{"韦小宝师父":{"兰陵王":"隐身"},"花木兰":[
# "唧唧复唧唧","木兰是战士",{"爸爸":["花和尚"]}]
# }},
# {"陈圆圆":"丈母娘"},{"穆建平":"小郡主"}]},
# 1005:{"常鑫":["大黑哥","大烧饼","吃大煎饼","肉夹馍","自行车","井盖",]}
# }
# print(dic)
# print(dic[1004]["韦小宝"][0]["教主夫人"][0])
# print(dic[1005]["常鑫"][-1])
# print(dic[1002]["汪峰"]["前妻2"][-1])
# print(dic[1004]["韦小宝"][4]["独臂神尼"]["韦小宝师父"]["兰陵王"])
# print(dic[1004]["韦小宝"][4]["独臂神尼"]["花木兰"][2]["爸爸"][0])
day05——字典的更多相关文章
- day05 字典
今日内容(dict) 1.基本格式 2.独有方法 3.公共 4.强制转换 1.基本格式 字典(可变类型,3.6之后是有序) 帮助用户去表示一个事物的信息(事物是有多个属性) 键值不能为集合,列表,字典 ...
- python day05字典
一.字典 1.字典的结构: a={key:value,key2:value},key是不可变的,value是可变的. 例子:dic = {123: 456, True: 999, "id&q ...
- day05 字典 dict
今日内容: 字典 成对的保存数据. 以key:value的形式保存 用{}表示,每一项内容都是key:value, 每项数据之间用逗号隔开 字典中的key是不能重复的. 存储是依靠着key来计算的. ...
- 记录我的 python 学习历程-Day05 字典/字典的嵌套
一.字典的初识 为什么要有字典 字典与列表同属容器型数据类型,同样可以存储大量的数据,但是,列表的数据关联性不强,并且查询速度比较慢,只能按照顺序存储. 什么是字典 先说一下什么叫可变与不可变的数据类 ...
- Python全栈--目录导航
这里更新以Python语言作为基础,想要成为全栈工程师需要掌握的技能... Python基础语法 day01 初识Python day02 while循环 运算符和编码 day03 字符串 day04 ...
- python学习之旅
python学习分类 python基础 +- day01——python初始.变量.常量.注释.基础数据类型.输入.if day02——while.字符串格式化.运算符.编码初识 day03—— ...
- 22期老男孩Ptython全栈架构师视频教程
老男孩Ptython全栈架构师视频教程 Python最新整理完整版22期视频教程 超60G课程容量<ignore_js_op> <ignore_js_op> <ignor ...
- 【DG】Oracle_Data_Guard官方直译
[DG]Oracle Data Guard官方直译 1 Oracle Data Guard 介绍 Oracle Data Guard概念和管理10g版本2 Oracle Data Guard ...
- DVWA实验之Brute Force(暴力破解)- Low
DVWA实验之Brute Force-暴力破解- Low 这里开始DVWA的相关实验~ 有关DVWA环境搭建的教程请参考: https://www.cnblogs.com/0yst3r-2 ...
随机推荐
- 十:装饰器模式(io流)
定义:装饰模式是在不必改变原类文件和使用继承的情况下,动态的扩展一个对象的功能.它是通过创建一个包装对象,也就是装饰来包裹真实的对象. 这一个解释,引自百度百科,我们 ...
- ubuntu玩坏之后
昨天,安装openssh-server的时候,与openssh-client冲突,故卸载openssh-client然后重装openssh-server解决问题. 今天,想装emacs,发现跟perl ...
- 【微信错误】{"errcode":"40013","errmsg":"invalid appid hint: [mackRA06203114]","success":false}
一.异常背景 发送可以跳转小程序的公众号模版消息 二.原因 当前公众号没有和被跳转的小程序关联 三.解决办法 去公众号平台将小程序和公众号进行关联就可以了
- 上云测试,这些关键点你get 到没有
导读,先从云化说起,再谈谈云化形态下,除了常规的功能测试,云化的测试,还需要有几个必须要get到的硬核指标,最后在分别详解这些关键点硬核指标是什么,和如何测试呢.这是个值得深思的问题,希望所有测试人都 ...
- CRT&EXCRT学习笔记
非扩展 用于求解线性同余方程组 ,其中模数两两互质 . 先来看一看两个显然的定理: 1.若 x \(\equiv\) 0 (mod p) 且 y \(\equiv\) 0 (mod p) ,则有 x+ ...
- 残差residual VS 误差 error
https://blog.csdn.net/jmydream/article/details/8764869 In statistics and optimization, statistical e ...
- Machine Learning in Finance – Present and Future Applications
https://emerj.com/ai-sector-overviews/machine-learning-in-finance/ Machine learning has had fruitful ...
- LG1983 「NOIP2013」车站分级 拓扑排序
问题描述 LG1983 题解 考虑建立有向边\((a,b)\),代表\(a\)比\(b\)低级. 于是枚举每一辆车次经过的车站\(x \in [l,r]\),如果不是车辆停靠的车站,则从\(x\)向每 ...
- Spring Cloud版本 version命名说明 (Edgware)
Spring Cloud版本 version命名说明 (Edgware) 版权声明:guofangsky 版权所有,转载不究. https://blog.csdn.net/guofangsky/a ...
- GIT : IDEA切换到某个tag
背景看一本presto的书,发现版本用的是presto-0.107这个版本.然后我去Apache clone下源码,发现分支只有几个,但是下载页面却有很多不同的版本 然后看Tag发现有很多. 然后我现 ...