Python cookbook(数据结构与算法)在字典中将键映射到多个值上的方法

作者:垄上行 时间:2023-07-14 14:37:00 

本文实例讲述了Python在字典中将键映射到多个值上的方法。分享给大家供大家参考,具体如下:

问题:一个能将键(key)映射到多个值的字典(即所谓的一键多值字典[multidict])

解决方案:如果想让键映射到多值,需要将这多个值保持到另一个容器如列表或集合中;


>>> d={'a':[1,2,3],'b':[4,5]}
>>> d
{'b': [4, 5], 'a': [1, 2, 3]}
>>> e={'a':{1,2,3,3},'b':{4,5}}
>>> e
{'b': {4, 5}, 'a': {1, 2, 3}}
>>> f={'a':[1,2,3,3],'b':[4,5]}
>>> f
{'b': [4, 5], 'a': [1, 2, 3, 3]}
>>>

更方便的创建这样的字典是利用collections模块中的defaultdict类。defaultdict的一个特点是它会自动给字典初始化第一个值,这样只需添加元素即可。例如:


from collections import defaultdict
d=defaultdict(list) #创建一键多值的字典,key的value是list类型
d['a'].append(1)
d['a'].append(2)
d['a'].append(2)
d['b'].append(4)
c=defaultdict(set) #创建一键多值的字典,key的value是set类型
c['a'].add(1)
c['a'].add(2)
c['a'].add(2)
c['b'].add(4)
print('key的value是list类型的字典:',d)
print('key的value是set类型的字典:',c)


>>> ================================ RESTART ================================
>>>
key的value是list类型的字典: defaultdict(<class 'list'>, {'b': [4], 'a': [1, 2, 2]})
key的value是set类型的字典: defaultdict(<class 'set'>, {'b': {4}, 'a': {1, 2}})
>>>

关于defaultdict需要注意的一点,他会自动创建字典表项以待稍后的访问(即使这些表项当前在字典中还没有找到)。

如果想取消这个功能,可以在普通的字典上调用setdefault()方法来取代,例如:


d={} #一个普通的字典
d.setdefault('a',[]).append(1)
d.setdefault('a',[]).append(2)
d.setdefault('a',[]).append(2)
d.setdefault('b',[]).append(4)
>>>

key的value是list类型的字典:


{'a': [1, 2, 2], 'b': [4]}

补充:

构建一个一键多值的字典很容易,但是如果试着自己对第一个值做初始化操作,这个会变得很杂乱,如果使用defaultdic后代码会简洁很多:


pairs={'a':[22,44],'b':[88]}
d=defaultdict(list)
for key,value in pairs.items():
 d[key].append(value)
print (d)
>>>
defaultdict(<class 'list'>, {'a': [[22, 44]], 'b': [[88]]})
>>>

(代码摘自《Python Cookbook》)

希望本文所述对大家Python程序设计有所帮助。

来源:http://www.cnblogs.com/apple2016/p/5744799.html

标签:Python,数据结构与算法,字典
0
投稿

猜你喜欢

  • 基于javascript实现最简单的选项卡切换效果

    2023-08-25 00:26:23
  • 盗亦有道 Web2.0网站优秀模仿者逐个数

    2007-09-11 19:46:00
  • Python实现简易的图书管理系统

    2021-09-12 06:06:21
  • 通过按钮实时切换CSS样式 实现CSS换肤的实例

    2008-07-17 12:55:00
  • Python中 传递值 和 传递引用 的区别解析

    2023-12-26 07:05:22
  • 详解小白之KMP算法及python实现

    2022-08-29 09:09:17
  • Go语言算法之寻找数组第二大元素的方法

    2023-06-24 16:19:03
  • Python基于dom操作xml数据的方法示例

    2023-02-15 10:18:30
  • 浅谈python3.x pool.map()方法的实质

    2022-07-30 22:27:30
  • 前端面试之vue2和vue3的区别有哪些

    2024-04-28 10:54:38
  • Pytorch如何切换 cpu和gpu的使用详解

    2023-08-22 03:30:11
  • Pytorch中retain_graph的坑及解决

    2022-12-20 16:21:09
  • 如何将 awk 脚本移植到 Python

    2022-02-28 05:40:52
  • Golang中的参数传递示例详解

    2024-05-08 10:51:33
  • SQL Server中单引号的两种处理技巧

    2008-05-23 13:30:00
  • Python 列表排序详解

    2022-08-14 05:05:21
  • 如何限制上传文件的大小?

    2010-06-09 18:47:00
  • 详解利用python-highcharts库绘制交互式可视化图表

    2022-05-05 14:29:53
  • javascript中substring()、substr()、slice()的区别

    2024-04-16 09:54:35
  • 解决python中的幂函数、指数函数问题

    2021-12-03 01:26:00
  • asp之家 网络编程 m.aspxhome.com