Python中使用字典的几个小技巧

1 解包

所谓解包,就是将字典通过 ** 操作符转为 Key=Value 的形式,这种形式可以直接传给函数作为关键字参数。

说说适用的几种情况。

1.1 搜索拼接条件

当应用中使用类似 SQLAlchemy 的 ORM 形式读取数据的时候,不同搜索条件,传入给 ORM 的搜索参数也随之改变。

下面是图书表的部分数据(只展示了部分字段)

+----+---------------+-------------------------+-------+
| id | category_name | book_name               | price |
+----+---------------+-------------------------+-------+
|  1 | 人文社科      | 人类简史                | 42.90 |
|  2 | 人文社科      | 世界简史                | 25.50 |
|  3 | 经济管理      | 极致产品                | 37.00 |
|  4 | 经济管理      | 史蒂夫·乔布斯传         | 44.20 |
|  5 | 经济管理      | 影响力                  | 41.20 |
+----+---------------+-------------------------+-------+

搜索时,我们会以这样的形式执行查询方法

books = Book.query.filter_by(id=1, book_name=‘影响力‘).all()

但是由于传入参数会根据搜索条件的变化而变化,无法直接写出有哪些参数,这个时候就可以使用字典解包

condition = {}
if book_id:
    condition[‘id‘] = id
if book_name:
    condition[‘name‘] = book_name
books = Book.query.filter_by(**condition).all()

这样就 OK 了

1.2 方法参数太多,为代码美观使用

new_book = Book(category_name=‘文学小说‘, book_name=‘解忧杂货店‘, price=28.8,
                ...)
db.session.add(new_book)

改成这样的话,美观一些

book_param = {‘category_name‘: ‘文学小说‘, ‘book_name‘: ‘解忧杂货店‘, ‘price‘: 28.8,
              ...}
new_book = Book(**book_param)
db.session.add(new_book)

并且,在上述新增图书过程中,都会对提交的参数进行校验,而校验方法返回的结果(也就是 book_param 和其它信息)一般也都是字典,所以使用字典解包的方式更符合实际场景。

总之,适当使用字典解包对方法进行传参,可以让我们的代码更灵活。

2 setdefault() 的使用

先看下这个方法怎么使用

dict.setdefault(key, default=None)

如果字典中包含有给定键,则返回该键对应的值,否则返回为该键设置的值。

很多时候我们需要对列表根据元素的某个 key 转化成一个包含列表的字典。比如,上面的数据中,我希望得到一个字典,字典的 key 是图书分类,value 是属于该分类的图书列表。我们通常会这样写

books_dict = {}
for book in book_list:
    if book[‘category_name‘] not in books_dict.keys():
        books_dict[book[‘category_name‘]] = []
    books_dict[book[‘category_name‘]].append(book)

当然,这样写是正确的,能得到预期结果

{
    "人文社科": [{
        "id": 1,
        "category_name": "人文社科",
        "book_name": "人类简史",
        "price": 42.9
    }, {
        "id": 2,
        "category_name": "人文社科",
        "book_name": "世界简史",
        "price": 25.5
    }],
    "经济管理": [{
        "id": 3,
        "category_name": "经济管理",
        "book_name": "极致产品",
        "price": 37.0
    }, {
        "id": 4,
        "category_name": "经济管理",
        "book_name": "史蒂夫·乔布斯传",
        "price": 44.2
    }, {
        "id": 5,
        "category_name": "经济管理",
        "book_name": "影响力",
        "price": 41.2
    }]
}

但是如果使用字典的 setdefault() 方法话,可以少写几行代码,看起来也优雅一些

books_dict = {}
for book in book_list:
    books_dict.setdefault(book[‘category_name‘], []).append(book)

3 字典合并

常用的合并方式

# new_dict = {**dict1, **dict2, ...}
# 合并多个字典,如果字典中存在相同的 key 的话,后面的会覆盖掉前面的
# 比如 dict2 会覆盖 dict1 中的 key 相同的值

>>> a = {‘name‘: ‘x‘, ‘age‘: 13}
>>> b = {‘name‘: ‘y‘}
>>> c = {**a, **b}
>>> c
{‘name‘: ‘y‘, ‘age‘: 13}

# dict1.update(dict2)
# 合并两个字典,如果字典中存在相同的 key 的话,dict2 会覆盖 dict1 的对应值
# 理解为更新某个字典应该更合适

>>> a.update(b)
>>> a
{‘name‘: ‘y‘, ‘age‘: 13}

有时我们碰到合并字典的情况也不少。比如,我们准备根据一本书的基本信息创建一本新书

# to_dict 将 ORM 对象转为字典,是自定义的,理解意思就好
base_book = Book.query.filter_by(id=1).first().to_dict()
# 提交的参数需要校验,校验成功后返回值包含 book_param ,内容和下面类似
book_param = {‘book_name‘: ‘国家宝藏‘, ‘price‘: 55.60}
# 同时需要更新新书的创建时间和更新时间
time_param = {‘created_at‘: current_time, ‘updated_at‘: current_time}
# 新增书籍
new_book = Book(**{**base_book, **book_param, **time_param})
db.session.add(new_book)

当然,如果只是合并两个字典的话,也可以使用 update() 方法。

假设我们只需要合并 base_bookbook_param

base_book.update(book_param)

这也可以工作,不过要注意,这样会修改 base_book 中的值。

如果只是单纯的更新某个字典的信息的话,update() 方法显然最合适。对于当前需求的话,还是第一种方式更合适。

本文首发于公众号「小小后端」,关注并回复「HMPython2018」领取 18 年很赞的 Python 学习教程。

原文地址:https://www.cnblogs.com/kevinbai/p/9961089.html

时间: 2024-10-14 10:58:13

Python中使用字典的几个小技巧的相关文章

Python中的字典详解

Python中的字典是python的一种数据结构,它的本质是key和value以及其对应关系的一种集合,一个key可以对应一个多个value.合理的使用字典能给我们编程带来很大的方便. -----python中的数据类型 -----python中的字符串操作 python3.0以上,print函数应为print(),不存在dict.iteritems()这个函数. 在python中写中文注释会报错,这时只要在头部加上# coding=gbk即可 #字典的添加.删除.修改操作dict = {"a&

Python中的字典

字段是Python是字典中唯一的键-值类型,是Python中非常重要的数据结构,因其用哈希的方式存储数据,其复杂度为O(1),速度非常快.下面列出字典的常用的用途. [字典中常见方法列表] #方法 #描述 ------------------------------------------------------------------------------------------------- D.clear() #移除D中的所有项 D.copy() #返回D的副本 D.fromkeys(s

Python中的字典及举例

字典 字典是python中的唯一的映射类型(哈希表) 字典对象是可变的,但是字典的键必须使用不可变对象,一个字典中可以使用不同类型的键值. 字典的方法 keys() values() items() 举例如下: In [10]: dic = {} In [11]: type(dic) Out[11]: dict In [12]: dic = {'a':1,1:123} In [13]: dic Out[13]: {1: 123, 'a': 1} In [14]: dic = {'a':1,1:1

python中的字典内置方法小结

#!/usr/local/bin/python3 # -*- coding:utf-8 -*- #key-value #dict 无序,无下标,不需要下标,因为有key stu={ 'stu001':"zhang yu", 'stu002':"ma hong yan", 'stu003':"zhang guo bin", 'stu004':"sha chun hua" } ''' -----------------------

python中的字典(dict)

首先说一下字典是什么: 字典是一种容器模型,可以通过搜索Key键获得其对应值得数据结构,字典可以储存任何类型的对象.字典里面的每个Key和value之间用冒号隔开.其键可以是字符串.数字.元组,字典是Python中唯一内置的映射类型. 注:键最好不要用浮点 字典所包含的方法如下表: 序号 方法 描述 1 clear(self) 删除字典里面的所有元素 2 copy(self) 返回值类型为字典,浅copy ,俗称赋值 3 fromkey(*args,**kwargs) 创建一个新字典,以序列se

Python中的字典排序

Python中比较常用的排序有两个函数, 一.定义 (1)一个是List数据结构中的sort >>> help(list.sort)Help on method_descriptor: sort(...) L.sort(cmp=None, key=None, reverse=False) -- stable sort *IN PLACE*; cmp(x, y) -> -1, 0, 1 The sort() method takes optional arguments for co

13.python中的字典

字典其实和之前的元祖和列表功能相似,都是用来储存一系列对象的.也就是一种可变容器,或者是我所比喻的革新派的菜单. 但也不是完全相同,我在之前曾经将字典称为特殊的'序列',是字典拥有序列的部分特性,但是又不符合序列的定义. 首先我们来看下字典是如何创建的: a = {'a':1,'b':2,'c':2} b = {} c = dict(a=1) print a print b print c 我们可以使用{} 或者dict() 来创建一个字典对象. 但字典里面写的是什么?下面我来分析一下. 首先,

Python 开发者节省时间的 10 个小技巧

Python 是一个美丽的语言,可以激发用户对它的爱.所以如果你试图加入程序员行列,或者你有点厌倦C++,Perl,Java 和其他语言,我推荐你尝试Python. Python有很多吸引程序员的功能 ,它易学,面向对象,字节码编译,免费且开源.还有运行时检查.完整快速的支持,可以执行各种任务的扩展. 高效的Python 在这篇文章,我想强调一些 Python 可以节约时间并最大限度地提高生产力的方面.在做准备时,我咨询了几个 Pythonists,他们最节省时间的技巧是什么?答案在这里… 1.

Win10 UWP开发中的重复性静态UI绘制小技巧 2

小技巧1 地址:http://www.cnblogs.com/ms-uap/p/4641419.html 介绍 我们在上一篇博文中展示了通过Shape.Stroke族属性实现静态重复性UI绘制,使得UWP界面的实现变得稍微灵活一些了. 但这一技巧还是有不少局限的,毕竟折腾StrokeDashArray属性看上去并不是那么直观和适用(还存在用扇形欺骗观众这样的“问题”啦). 这一篇博文我们将为大家介绍一种更为适用,同时也更为灵活和强大的重复性UI绘制技巧. ItemsControl.ItemsSo