7. ✎会查新华字典不?会。Python字典已经掌握了

梦想橡皮擦
• 阅读 1309

学编程要简单、粗暴。更要有效,很多时候学的越多,忘得越快。但编程总有那么一天顿悟的时候,而顿悟的契机目前就是建立在你跟橡皮擦坚持打卡 100 天,在评论区坚持跟橡皮擦卡学习的朋友,在 100 天之后,橡皮擦将送出 神秘大奖

七、查字典怎么查,Python 字典就怎么用

已经学完了列表与元组,那这两个都是按照顺序排列的,所以可以用索引取到值,本篇博客要学习的是字典,由上文可知,字典肯定就是不能按照索引取到值,就是没顺序,非序列的数据结构。

7.1 字典的基本操作

7.1.1 字典的定义

字典可以看成是一种列表型的数据结构,也是可以容纳很多其它数据类型的容器,但字典当中的元素使用 “键-值” 来表示的,而且“键-值” 成对出现,键与值之间存在的关系可以描述为,通过键取值(这个是字典的核心概念,就像通过部首查字典一样的)。

字典的语法格式如下:

# my_dict 是一个变量名
my_dict = {键1:值1,键2:值2......}

其中字典的值即上述格式中的 值1值2 可以是数值、字符串、列表、元组等内容。

例如可以通过字典来表示一个中英对照表。

my_dict = {"red": "红色", "green": "绿色", "blue": "蓝色"}
print(my_dict)
print(type(my_dict))

输出结果为:

{'red': '红色', 'green': '绿色', 'blue': '蓝色'}
<class 'dict'>

现在需要对字典再次建立一下认知,字典就是建立了键到值的一一对应关系。

7.1.2 获取字典的值

字典是通过键值定义的,通过键去获取值,因此字典中不允许出现重复的键。获取字典中值的语法格式为:

my_dict = {"red": "红色", "green": "绿色", "blue": "蓝色"}
print(my_dict["red"])

仔细看非常类似列表中元素的获取,只是将索引位置替换为了

7.1.3 字典中增加元素、修改元素、删除元素

增加元素

在字典中增加一个元素非常简单,只需要通过下述语法格式即可实现。

my_dict[键] = 值

例如在刚才的颜色翻译字典中在增加一个橙色的对应键值,代码如下:

my_dict = {"red": "红色", "green": "绿色", "blue": "蓝色"}
my_dict["orange"] = "橙色"

print(my_dict)

如果希望在字典中增加更多的键值对应关系,依次编写下去即可。

修改元素

修改字典中元素记住准确的应该叫做修改元素的值,例如将代码中 red 对应的值 红色 修改为 浅红色,通过下述代码完成。

my_dict = {"red": "红色", "green": "绿色", "blue": "蓝色"}
my_dict["red"] = "浅红色"

print(my_dict)

通过 my_dict[要修改的键] = 新的值 来进行修改即可完成任务。

删除元素

如果想要删除字典中某一个具体的元素,只需要通过 del 关键字加上 my_dict[待删除元素的键] 即可完成。

my_dict = {"red": "红色", "green": "绿色", "blue": "蓝色"}
del my_dict["red"]

print(my_dict)

以上内容可以删除特定元素,使用字典的一个 clear 方法,可以将字典清空。

my_dict = {"red": "红色", "green": "绿色", "blue": "蓝色"}
my_dict.clear()

print(my_dict)

以上内容会输出 {} 该符号表示空字典。

除了将字典清空以外,还可以直接将字典变量删除。

my_dict = {"red": "红色", "green": "绿色", "blue": "蓝色"}
del my_dict

print(my_dict)

删除字典变量之后,在打印 my_dict 程序直接报错,提示 name 'my_dict' is not defined 变量未定义,在删除字典的时候一定要注意别误删整个字典,除非程序要求这么实现。

7.1.4 字典的补充知识

空字典

刚才其实已经提及了一个空字典是如何创建的,建立空字典的语法如下:

my_dict = {}

空字典一般用于逻辑占位,好复杂啥叫逻辑占位,就是先声明后面在进行扩展的一个小技巧。

获取字典元素数量

列表与元组都可以使用 len 来获取元素数量,同样的方法适用于字典,语法格式如下:

my_dict_length = len(my_dict)

空字典的元素数量为 0,可以进行尝试一下。

字典可读性书写

在很多时候一个程序不是由一个人可以独立完成,需要一个团队进行配合,如何让自己的代码可读性(别人能看懂)变高在代码编写的时候就变的非常重要了。字典为了增加可读性,建议一行定义一个元素。

my_dict = {"red": "红色",
           "green": "绿色",
           "blue": "蓝色"}

print(my_dict)

7.2 字典的遍历

字典也需要遍历输出里面的每一个元素,对于字典咱已经知道是由键值对组成,那对应的遍历输出内容就有所有键值,所有键,所有值。

7.2.1 遍历字典的键 - 值

调用字典的 items 方法可以获取字典的所有键值,例如下述代码:

my_dict = {"red": "红色",
           "green": "绿色",
           "blue": "蓝色"}

print(my_dict.items())

该内容输入为:

dict_items([('red', '红色'), ('green', '绿色'), ('blue', '蓝色')])

接下来循环输出字典内容,有几种不同的写法,先尝试编写如下代码,在进行知识点学习。

my_dict = {"red": "红色",
           "green": "绿色",
           "blue": "蓝色"}

# 直接对 my_dict 进行遍历
for item in my_dict:
    print(item)

# 遍历 my_dict 的 items 方法
for item in my_dict.items():
    print(item)

# 遍历 my_dict 的 items 方法,并用 key 与 value 接收
for key,value in my_dict.items():
    print("键:{},值:{}".format(key,value))

以上三种输出内容请自行查阅。

  1. 第一种输出的是所有的
  2. 第二种将每个键值对当做一个元组输出;
  3. 第三种通过变量与元组之间的赋值直接将键与值输出。

关于变量与元组之间的赋值可以参考下属代码:

a,b = (1,2)
print(a)
print(b)

注意通过该方式进行变量的赋值一定要将左侧的变量与右侧元组中的元素做好对应,一个变量对应元组中的一项,顺序也对应。如果不对应就会出现下述错误 ValueError: too many values to unpack

7.2.2 遍历字典的键

上文学习到的是遍历字典的键值,你可以直接通过 keys 方法获取字典的所有键,例如下述代码:

my_dict = {"red": "红色",
           "green": "绿色",
           "blue": "蓝色"}


for key in my_dict.keys():
    print(key)

7.2.3 遍历字典的值

有 keys 方法获取键,对应的就是通过 values 获取所有值。 这个地方因为和上述内容太相似了,如果想成为一个合格的程序员,学习初期每天的代码量是不能减少的,所以本部分留给你啦。

7.3 字典与其他数据类型的结合

先要认识到字典是一个容器,它可以包含任意数据类型。字典也是一种数据类型,它可以被列表与字典本身等容器类包含。 很绕是吧,其核心是非常简单的,看完代码你就明白了。

7.3.1 列表嵌套字典

直接看效果,一个列表可以嵌套字典。

my_list = [{"name": "橡皮擦", "age": 18},
           {"name": "大橡皮擦", "age": 20}]
print(my_list)
print(my_list[0])

7.3.2 字典嵌套列表

字典中元素的值可以是列表,具体如下:

my_dict = {"colors": ["红色","绿色"],
           "nums": [1,2,3,4,5],
           "name": ["橡皮擦"]}
print(my_dict)

7.3.3 字典嵌套字典

字典的值可以为任意数据类型,那自然可以是字典类型,所以下述代码你应该可以阅读。

my_dict = {"colors": {"keys": ["红色", "绿色"]},
           "nums": [1, 2, 3, 4, 5],
           "name": ["橡皮擦"]}
print(my_dict)

以上内容都是非常简单的写法,总结一句话都是套娃。

7.4 字典的方法

字典有一些特殊的方法需要单独说明一下,如果想要查看字典所有的方法,依据使用 dir 内置函数调用。

7.4.1 fromkeys 方法

该方法目的是创建一个字典,语法格式如下:

# 注意该方法直接通过 dict 调用
# seq 是一个序列,可以为元组,也可以是字典
my_dict = dict.fromkeys(seq)

接下来就通过该方法实际创建一个字典。

my_list = ['red', 'green']

my_dict = dict.fromkeys(my_list)
# 以下内容输出 {'red': None, 'green': None}
print(my_dict)

my_dict1 = dict.fromkeys(my_list, "字典的值")
print(my_dict1)

第一种方式发现输出的字典中所有值为 None(Python 中的特殊值,相当于空),该内容是由于没有设置字典默认值,缺省为 None,如果需要在定义字典的时候初始化该值,在方法中的第二个参数赋值即可。

7.4.2 get 方法

get 方法用于通过键获取值,如果不存在可以设置返回一个默认值,例如下述代码:

my_dict = {"red": "红色",
           "green": "绿色",
           "blue": "蓝色"}
print(my_dict.get("red"))  # 返回红色
print(my_dict.get("red1")) # 返回 None

print(my_dict.get("red1","设置一个找不到返回的默认值"))

7.4.3 setdefault 方法

setdefault 方法与 get 方法用途基本一致,区别是当 setdefault 搜寻不到指定键时,会自定将键值插入字典,例如下述代码:

my_dict = {"red": "红色",
           "green": "绿色",
           "blue": "蓝色"}
print(my_dict.setdefault("red")) # 返回红色
print(my_dict.setdefault("orange")) # 返回 None
print(my_dict) # 输出 {'red': '红色', 'green': '绿色', 'blue': '蓝色', 'orange': None}

最后一行代码输出的结果中已经包含了键 orange 与值 None,你可以在使用 dict.setdefault("orange","橙色") 测试一下默认值。

7.4.4 pop 方法

该方法用于删除字典元素,语法格式如下:

ret_value = dict.pop(key[,default])

既然已经写出了这种标准格式,那先补充一下语法格式的规范,例如 dict.pop(key[,default])key 表示必填参数,[] 包括的参数为非必填参数,这样你可以理解上述语法格式内容是什么了。

my_dict = {"red": "红色",
           "green": "绿色",
           "blue": "蓝色"}

# 删除指定项
ret_value = my_dict.pop('red')
# 输出被删除的红色
print(ret_value)
# 查看字典 {'green': '绿色', 'blue': '蓝色'}
print(my_dict )

在使用 pop 方法的时候如果找到 key,就会删除该键值对,如果找不到 key 会返回 defalut 设置的值,如果该值没有设置,会报错。

my_dict = {"red": "红色",
           "green": "绿色",
           "blue": "蓝色"}

# 删除指定项,如果没有设置找不到返回的值,直接报错
ret_value = my_dict.pop('red2')

# 删除指定项,找不到 key1 返回后面设置的值
ret_value = my_dict.pop('red1',"找不到返回的值")

7.5 这篇博客的总结

字典同列表、元组一样都是 Python 中非常重要的数据类型,字典因为键值对的概念存在导致其使用场景更多,初学阶段橡皮擦给大家的意见就是好好的打打代码,先建立对 Python 的整体认知,滚雪球学 Python,这只是第一遍滚。

最后一碗毒鸡汤

我曾天真地以为金钱是万能的,后来才发现,金钱不是万能的,是无所不能的。 O(∩_∩)O 哈哈~

🌸🌸🌸🌸🌸🌸🌸🌸


点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
梦想橡皮擦 梦想橡皮擦
3年前
8. ㊙ Python 集合三板斧,滚雪球学 Python
学编程要简单、粗暴。更要有效,很多时候学的越多,忘得越快。但编程总有那么一天顿悟的时候,而顿悟的契机目前就是建立在你跟橡皮擦坚持打卡100天,在评论区坚持跟橡皮擦卡学习的朋友,在100天之后,橡皮擦将送出神秘大奖。八、Python中一个无序且元素唯一的数据类型,它是集合。8.1集合是啥集合是一个数据类型,它其中的每个元素的顺
Stella981 Stella981
3年前
Python之time模块的时间戳、时间字符串格式化与转换
Python处理时间和时间戳的内置模块就有time,和datetime两个,本文先说time模块。关于时间戳的几个概念时间戳,根据1970年1月1日00:00:00开始按秒计算的偏移量。时间元组(struct_time),包含9个元素。 time.struct_time(tm_y
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
3年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Stella981 Stella981
3年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
10个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这