Python入门之字典的使用教程
作者:胡安民-独行者 发布时间:2021-09-15 00:35:12
前沿
Python字典是一种可变容器模型,且可存储任意类型对象,如字符串、数字、元组等其他容器模型。
字典的每个键值key=>value对用冒号 : 分割,每个对之间用逗号,分割,整个字典包括在花括号{}中 ,格式如下: {key1 : value1, key2 : value2 }
字典操作
创建字典
字典由键和值组成,字典中所有键值均要放在 大括号 {} 里面,键与值之间通过冒号 : 分割,而每一对键值之间则通过 逗号 , 间隔起来,其格式如下:
dic1 = {"a": "天猫", 2: "京东", "c": "拼多多", "C": "PDD"}
需要注意的是,字典中的键必须是唯一的,同时字典的键必须是不可变对象,如 字符串、数字 等,而键对应的值,则可以是任意数据类型。
嵌套字典
myfamily = {
"child1" : {
"name" : "Phoebe Adele",
"year" : 2002
},
"child2" : {
"name" : "Jennifer Katharine",
"year" : 1996
},
"child3" : {
"name" : "Rory John",
"year" : 1999
}
}
dict() 创建字段
thisdict = dict(brand="Porsche", model="911", year=1963)
# 请注意,关键字不是字符串字面量
# 请注意,使用了等号而不是冒号来赋值
print(thisdict)
访问字典中的值
在字典中,我们需要通过字典的键来访问其对应的值。
通过 dict[key] 取值
dict1 = {"name": "wintest", "age": 13}
print(dict1["name"])
如果键不存在,那么取值时就会报错:KeyError: ‘xxx’
通过 get(key) 取值
dict1 = {"name": "wintest", "age": 13}
print(dict1.get("name"))
如果键不存在,那么取值时会返回 None ,并不会报错,这种情况下我们也可以让其返回一个指定的值,该操作并不会影响字典的键值。如下:
dict1.get("name", "123") # name键存如果不存在那么返回123
更新字典
通过 dict[key] 修改字典
在字典中,我们可以通过字典的键 dict[key] 来修改其对应值,如果键不存在,那么就会把该键值对添加到字典中。
dict1 = {"name": "wintest", "age": 13}
# 如果不存在那么就是添加,如果存在那么就是修改
dict1["xxx"] = "123"
dict1["age"] = 66
在上面我们提到,字典中的键必须是唯一的,如果在创建字典时对同一个键赋值多次,那么只有最后一个值会被记住,因为对同一个键多次赋值时,其实就相当于 dict[key] 对字典进行修改。
通过 update(dict) 修改字典
字典中的 update() 方法,传入参数需要是一个新字典,该操作会把新字典中的键值对更新到原字典中。
dict1 = {"name": "wintest", "age": 13}
dict2 = {"name": "hihihi", "sex": "?"}
dict1.update(dict2) # 把 dict2 中键值对,更新到 dict1 中 ,存在就更新不存在就添加
print(dict1)
删除字典元素
通过 del 删除字典中的键值对
dict1 = {"name": "wintest", "age": 13}
del dict1["name"]
print(dict1)
如果被删除的键不存在那么就会报错KeyError: ‘xxx’
通过 pop() 删除字典中的键值对
dict1 = {"name": "wintest", "age": 13}
dict1.pop("name")
print(dict1)
dict1.clear() # 清空字节, 只是内容被清空了, 也就是{}
del dict1 # 删除整个字典,被删除的dict1 没法被使用了
使用 pop() 方法有一个好处,如果要删除的键值对不存在,那么就可以设置指定返回值来避免出现报错,如下:
dict1 = {"name": "wintest", "age": 13}
del_V=dict1.pop("xxx", "不存在的key") # 键不存在,指定返回值
print(del_V)# 不存在的key
删除最后插入的键值对 popitem()
car = {
"brand": "Porsche",
"model": "911",
"year": 1963
}
x = car.popitem()
print(x) # ('year', 1963)
检查键是否存在
要确定字典中是否存在指定的键,请使用 in 关键字:
dict1 = {"name": "wintest", "age": 13}
print("name" in dict1) # True
字典的遍历
字典在遍历时,也可以类似列表、集合等数据类型,通过关键字 in 来实现。
dict1 = {"name": "wintest", "age": 13}
for key in dict1:
print(key, dict1[key])
我们也可以使用 dict1.items() ,先以列表返回一个视图对象,然后对其遍历时,可以直接获取到字典中的键和值,如下:
dict1 = {"name": "wintest", "age": 13}
for key, value in dict1.items():
print(key, value)
您还可以使用 values() 函数返回字典的值:
dict1 = {"name": "wintest", "age": 13}
for x in dict1.values():
print(x)
字典函数
获取字段的长度
dict1 = {"name": "wintest", "age": 13}
print(len(dict1)) # 2
复制字典
您不能通过键入 dict2 = dict1 来复制字典,因为:dict2 只是对 dict1 的引用,而 dict1 中的更改也将自动在 dict2 中进行。 有一些方法可以进行复制,一种方法是使用内建的字典方法 copy()。
thisdict = {
"brand": "Porsche",
"model": "911",
"year": 1963
}
mydict = thisdict.copy()
print(mydict)
制作副本的另一种方法是使用内建方法 dict()。
thisdict = {
"brand": "Porsche",
"model": "911",
"year": 1963
}
mydict = dict(thisdict)
print(mydict)
批量创建键
x = ('key1', 'key2', 'key3')
thisdict = dict.fromkeys(x,None)
print(thisdict) # {'key1': None, 'key2': None, 'key3': None}
来源:https://blog.csdn.net/weixin_45203607/article/details/126707125


猜你喜欢
- 注:本次实验的数据在文章最后面,我已上传至百度网盘一.json模块对数据进行处理 上面三个txt文本是这三个国家疫情爆发相关的数据
- python3中str默认为Unicode的编码格式Unicode是一32位编码格式,不适合用来传输和存储,所以必须转换成utf-8,gbk
- 需要下载某网站的视频,chrome浏览器按F12打开开发者模式,发现视频链接是以"blob:http"开头的链接,打开这
- Python3进制之间的转换在Python里面实现进制之间的转换是非常方便的,有专门的函数来进行这个操作:下面直接上代码:# 进制之间的转换
- 在windows+iis服务器上运行asp程序可能会出现数据库无法更新的情况,具体错误信息可能为: 1、Microsoft JET Data
- 方案:◆1、SELECT TOP PAGESIZE NEWSTITLEFORM NEWSINFO WHERE NEWSID NOT IN(S
- 1.使用str.split()方法可以使用pandas 内置的 str.split() 方法实现分割字符串类型的数据,并将分割结果写入Dat
- 下载:pip install apschedulerpip install django-apscheduler将 django-apsch
- PyQt中的线程类 QtCore.QThread ,使用时继承QThread类启动界面的线程暂称为UI线程。界面执行命令时都在自己的UI线程
- 在日常开发中,我们进行用户登录的时候,大部分情况下都会使用 session 来保存用户登录信息,并以此为依据判断用户是否已登录。但其实 HT
- 网上我也见到一些分栏效果,也有一个jquery的插件jquery.splitter.js, 但是他们基本都没有解决一个问题:如果页面上有if
- MySQL5.7及以上版本提供直接查询冗余索引、重复索引和未使用过索引的视图,直接查询即可。查询冗余索引、重复索引select * sys.
- XML文档对象模型(DOM)是什么?可扩展标记语言XML的基础是 DOM。XML 文档具有一个称为节点的信息单元层次结构;DOM 是描述那些
- Jinja是组成Flask的模板引擎。可能你还不太了解它是干嘛的,但你对下面这些百分号和大括号肯定不陌生:{% block body %}
- 本文实例为大家分享了微信小程序实现计算器的具体代码,供大家参考,具体内容如下1、实现效果图2、代码编写index.wxml<!--au
- 需求:小程序端拍照调用python训练好的图片分类模型。实现图片分类识别的功能。微信小程序端:重点在chooseImage函数中,根据图片路
- python关系图的可视化主要就是用来分析一堆数据中,每一条数据的节点之间的连接关系从而更好的分析出人物或其他场景中存在的关联关系。这里使用
- 我们经常会用到表格数据,在做表格的时候,一般都喜欢隔行变色,使表格表现数据的时候非常的清晰。如图,我设计的一个表格表现的样式:在网上找到一个
- 一、概述dba在工作中避不开的两个问题,sql使用绑定变量到底会有多少的性能提升?数据库的审计功能如果打开对数据库的性能会产生多大的影响?最
- 新建py文件,在里面写入Python代码,代码的功能是打印10次“Hello!”,将代码文件保存到桌面上:在命令行中运行Python脚本,并