Python编程根据字典列表相同键的值进行合并
作者:曲鸟 发布时间:2023-09-29 20:10:54
标签:python,字典列表,键值合并
一、前言
今天有粉丝咨询了一个问题,他现在有两个列表,它们的元素都为字典,且字典都有一个key
为id,现在想把这两个字典根据id合并为一个字典,类型下面的效果:
两个列表的数据为:
a_list = [{'id': 1, 'value': 11}, {'id': 2, 'value': 22}, {'id': 3, 'value': 33}]
b_list = [{'id': 1, 'name': 'a'}, {'id': 2, 'name': 'b'}, {'id': 3, 'name': 'c'}]
期望合并的结果
[{'id': 1, 'name': 'a', 'value': 11},
{'id': 2, 'name': 'b', 'value': 22},
{'id': 3, 'name': 'c', 'value': 33}]
二、实现分析
这是粉丝写的实现代码:
for i in range(len(b_list)):
for a in a_list:
if b_list[i]['id'] == a['id']:
b_list[i]['value'] = a['value']
print(b_list)
通过两个for循环来将a_list
中元素字典id
值等于b_list
元素字段id
值的值加入到对应的b_list
元素字典中。
实际上两行代码就可以解决这个问题:
1.我们可以先通过推导式将a_list
重新组装为{id:value}
的形式
a_values = {a['id']: a['value'] for a in a_list}
a_values的值为:
{1: 11, 2: 22, 3: 33}
2.然后再通过推导式和字典解构再合并的方式将值与b_list
重新组装:
res_list = [{**b, **{'value': a_values[b['id']]}} for b in b_list]
组装后的列表值为
res_list的值为:
[{'id': 1, 'name': 'a', 'value': 11},
{'id': 2, 'name': 'b', 'value': 22},
{'id': 3, 'name': 'c', 'value': 33}]
完整示例代码
a_list = [{'id': 1, 'value': 11}, {'id': 2, 'value': 22}, {'id': 3, 'value': 33}]
b_list = [{'id': 1, 'name': 'a'}, {'id': 2, 'name': 'b'}, {'id': 3, 'name': 'c'}]
a_values = {a['id']: a['value'] for a in a_list}
res_list = [{**b, **{'value': a_values[b['id']]}} for b in b_list]
print('res_list的值为:', res_list)
当然一行代码也可以搞定,直接把两个推导式合并
res_list = [{**b, **{'value': {a['id']: a['value'] for a in a_list}[b['id']]}} for b in b_list]
但这就是为了装X而写代码了,毫无必要!
三、总结
就是推导式和字典通过**
解构来合并这两个知识点。
来源:https://blog.csdn.net/momoda118/article/details/120406132


猜你喜欢
- 使用到的库好多人都想了解一下如何对摄像头进行调用,然后进行目标检测,于是我做了这个小BLOG。opencv-python==4.1.2.30
- PDO是PHP 5新加入的一个重大功能,因为在PHP 5以前的php4/php3都是一堆的数据库扩展来跟各个数据库的连接和处理,什么 php
- DateDiff 函数描述 返回两个日期之间的时间间隔。 语法 DateDiff(interval, date1, date2 [,firs
- 本文实例讲述了Python实现爬取亚马逊数据并打印出Excel文件操作。分享给大家供大家参考,具体如下:python大神们别喷,代码写的很粗
- Python 多线程的实例详解一)线程基础1、创建线程:thread模块提供了start_new_thread函数,用以创建线程
- 一、前言相关知识来自《python算法设计与分析》。初级排序算法是指几种较为基础且容易理解的排序算法。初级排序算法包括插入排序、选择排序和冒
- 本文实例讲述了微信小程序之事件交互操作。分享给大家供大家参考,具体如下:微信小程序—点击事件什么是事件?指点击,触摸,按下,滑动,松开,等一
- 视频才用流媒体,有后台实时返回数据, 要支持flash播放, 所以需安装对应的flash插件。当视频播放时,每间隔3秒向后台发送请求供检测心
- 前言:无意间留意到一个面试题,需求是利用js将手机号中间四位变成*号,简单记录一下。1. 利用字符串的substr方法 substr() 方
- 大家都知道系统存储过程是无法用工具导出的(大家可以试试 >任务>生成SQL脚本) 因为系统存储过程一般是不让开发人员修改的。 需
- 问题概述:有时候在使用print函数输出时,往往需要不断地切换字符串和变量,操作起来很不方便,需要不断地打引号和逗号。比如:firstNam
- 前言针对一些特殊的需求,在项目里,需要将响应式数据变为普通原始类型数据,这种情况是有的在Vue里,能够将普通数据类型的数据变为响应式数据,同
- 1. set 的基本内容1.基本特点(1) 无序性(2) 确定性(3) 不重复性2.set() 实质内部进行 可迭代性的 for 循环例子:
- 定义一个什么都不做的函数>>> def a():... pass...>>> def printHell
- 本篇文章将介绍3种常见的数据结构和同数据有关的算法。此外,在collections模块中也包含了针对各种数据结构的解决方案。Python内置
- 目录01 安装02 剪辑01 安装对视频进行批量剪辑,需要三个库,分别是Moviepy库和Pathlib库,还有Tkinter库。首先我们对
- python代码如下:import webbrowser as wbimport foliumif __name__ == '__m
- 本文实例讲述了ASP.NET数据库操作类。分享给大家供大家参考,具体如下:using System;using System.Data;us
- IFRAME 元素 | iframe 对象创建内嵌浮动框架。成员表下面的表格列出了 iframe 对象引出的成员。请单击左侧的标签来选择你想
- JDBC数据库连接MySQL中建表在终端使用命令mysql -u root -p打开数据库,在数据库操作环境下进行创建数据库,建表等等操作建