Python cookbook(数据结构与算法)字典相关计算问题示例


Posted in Python onFebruary 18, 2018

本文实例讲述了Python cookbook(数据结构与算法)字典相关计算问题。分享给大家供大家参考,具体如下:

问题:在字典上对数据执行各式各样的计算(比如求最小值、最大值、排序)。

解决方案:利用zip()将字典的键-值对“反转”为值-键对序列。

例如:如下字典存放的股票名称和对应的价格:

>>> prices = {
 'ACME': 45.23,
 'AAPL': 612.78,
 'IBM': 205.55,
 'HPQ': 37.20,
 'FB': 10.75
}
>>> prices
{'HPQ': 37.2, 'IBM': 205.55, 'FB': 10.75, 'ACME': 45.23, 'AAPL': 612.78}
>>> min_price = min(zip(prices.values(), prices.keys())) #注意zip(x,y)中参数的顺序
>>> max_price = max(zip(prices.values(), prices.keys()))
>>> min_price
(10.75, 'FB')
>>> max_price
(612.78, 'AAPL')
>>> prices_sorted = sorted(zip(prices.values(), prices.keys()))
>>> prices_sorted
[(10.75, 'FB'), (37.2, 'HPQ'), (45.23, 'ACME'), (205.55, 'IBM'), (612.78, 'AAPL')]
>>> min_price2 = min(zip(prices)) #错误用法
>>> min_price2
('AAPL',)
>>> max_price2 = max(zip(prices)) #错误用法
>>> max_price2
('IBM',)
>>> min_price3 = min(zip(prices.keys(), prices.values())) #zip()参数顺序不对,获取错误的值
>>> min_price3
('AAPL', 612.78)
>>> max_price3 = max(zip(prices.keys(), prices.values())) #zip()参数顺序不对,获取错误的值
>>> max_price3
('IBM', 205.55)
>>>

进行这些计算时,请注意zip()创建了一个迭代器,它的内容只能消费一次。例如:

>>> pirces_and_names=zip(prices.values(), prices.keys())
>>> pirces_and_names
<zip object at 0x023BDFA8>
>>> min(pirces_and_names)
(10.75, 'FB')
>>> max(pirces_and_names)
Traceback (most recent call last):
 File "<pyshell#25>", line 1, in <module>
 max(pirces_and_names)
ValueError: max() arg is an empty sequence
>>>

注意:当涉及(value,key)对的比较时,碰巧有多个条目拥有相同的value值,那么此时key将用来作为判定结果的依据。

>>> prices={'AAA':45.23,'ZZZ':45.23}
>>> min(zip(prices.values(), prices.keys()))
(45.23, 'AAA')
>>> max(zip(prices.values(), prices.keys()))
(45.23, 'ZZZ')
>>>

(代码摘自《Python Cookbook》)

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

Python 相关文章推荐
浅谈Python中数据解析
May 05 Python
浅谈python新手中常见的疑惑及解答
Jun 14 Python
JPype实现在python中调用JAVA的实例
Jul 19 Python
PyQt5每天必学之组合框
Apr 20 Python
python re正则匹配网页中图片url地址的方法
Dec 20 Python
使用TensorFlow-Slim进行图像分类的实现
Dec 31 Python
python3 自动打印出最新版本执行的mysql2redis实例
Apr 09 Python
基于python 取余问题(%)详解
Jun 03 Python
Python如何给你的程序做性能测试
Jul 29 Python
Python文件名匹配与文件复制的实现
Dec 11 Python
python 三种方法提取pdf中的图片
Feb 07 Python
pytorch锁死在dataloader(训练时卡死)
May 28 Python
Python cookbook(数据结构与算法)让字典保持有序的方法
Feb 18 #Python
Python cookbook(数据结构与算法)在字典中将键映射到多个值上的方法
Feb 18 #Python
Python cookbook(数据结构与算法)实现优先级队列的方法示例
Feb 18 #Python
python快速建立超简单的web服务器的实现方法
Feb 17 #Python
Python cookbook(数据结构与算法)找到最大或最小的N个元素实现方法示例
Feb 13 #Python
python3学习笔记之多进程分布式小例子
Feb 13 #Python
Python cookbook(数据结构与算法)保存最后N个元素的方法
Feb 13 #Python
You might like
apache+codeigniter 通过.htcaccess做动态二级域名解析
2012/07/01 PHP
如何在php中正确的使用json
2013/08/06 PHP
php使用mkdir创建多级目录入门例子
2014/05/10 PHP
php连接与操作PostgreSQL数据库的方法
2014/12/25 PHP
Swoole源码中如何查询Websocket的连接问题详解
2020/08/30 PHP
Alliance vs Liquid BO3 第一场2.13
2021/03/10 DOTA
一个JavaScript继承的实现
2006/10/24 Javascript
阻止JavaScript事件冒泡传递(cancelBubble 、stopPropagation)
2007/05/08 Javascript
js中的escape及unescape函数的php实现代码
2007/09/04 Javascript
Jquery的Tabs内容轮换效果实现代码,几行搞定
2014/02/12 Javascript
深入解析Javascript闭包的功能及实现方法
2016/07/10 Javascript
JS异步文件上传(兼容IE8+)
2017/04/02 Javascript
微信小程序城市定位的实现实例(获取当前所在国家城市信息)
2017/05/17 Javascript
Linux系统中利用node.js提取Word(doc/docx)及PDF文本的内容
2017/06/17 Javascript
js读取本地文件的实例
2017/12/22 Javascript
vue路由前进后退动画效果的实现代码
2018/12/10 Javascript
vue 详情跳转至列表页实现列表页缓存
2019/03/27 Javascript
vue前端框架—Mint UI详解(更适用于移动端)
2019/04/30 Javascript
[33:23]VG vs Pain 2018国际邀请赛小组赛BO2 第二场 8.18
2018/08/19 DOTA
opencv 获取rtsp流媒体视频的实现方法
2019/08/23 Python
python3 assert 断言的使用详解 (区别于python2)
2019/11/27 Python
python实现最短路径的实例方法
2020/07/19 Python
多个版本的python共存时使用pip的正确做法
2020/10/26 Python
巧克力领导品牌瑞士莲美国官网:Lindt Chocolate美国
2016/08/25 全球购物
KELLER SPORTS荷兰:在线订购最好的运动产品
2020/10/13 全球购物
阿里巴巴Oracle DBA笔试题答案-备份恢复类
2013/11/20 面试题
土木工程建筑专业毕业生求职信
2013/10/21 职场文书
网络工程专业毕业生推荐信
2013/10/28 职场文书
高中物理教学反思
2014/02/08 职场文书
大学生两会精神学习心得体会
2014/03/10 职场文书
二手房购房意向书范本
2014/04/01 职场文书
《观舞记》教学反思
2014/04/16 职场文书
小学一年级学生评语
2014/04/22 职场文书
市场营销工作计划书
2014/05/06 职场文书
幼儿老师求职信
2014/06/30 职场文书
社区娱乐活动方案
2014/08/21 职场文书