一日一技:让你的字典读取不报错

简介: 一日一技:让你的字典读取不报错

摄影:产品经理厨师:kingname

我们知道,读取 Python 字典时,如果某个 Key 不存在,Python 就会报错,如下图所示:

为了防止它报错,我们可以使用.get()方法:


但每次都要写.get()稍显麻烦。于是我们可以通过自己实现一个自定义的字典对象,来解决这个问题。

我们自定义一个类,继承dict,然后实现它的__missing__方法:

class OurDict(dict):
    def __missing__(self, key):
        returnNone
a = OurDict({'a': 1, 'b': 2})
print(a['x'])

运行效果如下图所示:

只要这个 Key 不存在,就会返回 None

在 Python 的collections工具模块中,有一个defaultdict实现了类似的事情。我们看它的使用方法。

from collections import defaultdict
a = defaultdict(str)
a['a'] = 1
a['b'] = 2
print(a)
print(a['x'])
print(a)

a = defaultdict(str)接收一个函数,让a变量成为一个defaultdict类型的对象,它可以像普通字典一样被赋值和读取。

但是当你读取一个不存在的 key 时,它会自动生成一个默认值,并把默认值和这个 key 插入到字典中。这个默认值取决于你在defaultdict传入的参数。如果传入的是str那么默认值就是空字符串,如果是int那么默认值就是0.当然你也可以传入自定义的一个函数,从而控制这个默认值。例如我自定义一个函数,用于返回当前的时间,运行效果如下图所示:

当插入的 key 不存在时,就自动以当前时间作为默认值,并存入到字典中。


目录
相关文章
|
4月前
|
存储 弹性计算 运维
从文件中删除重复的行
【4月更文挑战第29天】
36 1
|
4月前
|
Python
基于Python读取Excel表格文件数据并转换为字典dict格式
基于Python读取Excel表格文件数据并转换为字典dict格式
基于Python读取Excel表格文件数据并转换为字典dict格式
|
开发者 索引 Python
#PY小贴士# 字典可以通过序号索引来访问?
不过在实际开发中,除非有特殊需求,或者和你的合作开发者有仇,否则不太建议用这种方式来设定字典的键。
|
JSON 数据格式
数组与字典(JSON)通过字符串快捷取值
数组与字典(JSON)通过字符串快捷取值
93 0
|
存储 索引 Python
12.从入门到精通:Python字典,创建字典,访问字典的值,修改字典,删除字典,字典键的特性,字典内置函数和方法
12.从入门到精通:Python字典,创建字典,访问字典的值,修改字典,删除字典,字典键的特性,字典内置函数和方法
|
Python
python如何读取xlsx文件,并指定读取某一列,逐个逐个取出指定列中的值
要读取xlsx文件并指定读取某一列,可以使用Python中的pandas库。以下是一个读取xlsx文件并逐个逐个取出指定列中的值的示例代码:
1238 0
|
数据格式 Docker 容器
准备字典数据
准备字典数据
111 0
内置字典配置说明
内置字典配置说明
109 0
vbs的字典存入和读取操作 comparemode属性
vbs的字典存入和读取操作 comparemode属性