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正则表达式教程之一:基础篇
Mar 02 Python
Python实现简单网页图片抓取完整代码实例
Dec 15 Python
基于Python实现的微信好友数据分析
Feb 26 Python
浅析python实现scrapy定时执行爬虫
Mar 04 Python
Python常用模块之requests模块用法分析
May 15 Python
python内存管理机制原理详解
Aug 12 Python
python 串口读取+存储+输出处理实例
Dec 26 Python
Python实现CNN的多通道输入实例
Jan 17 Python
Python @property原理解析和用法实例
Feb 11 Python
python可迭代对象去重实例
May 15 Python
Java Unsafe类实现原理及测试代码
Sep 15 Python
python基础之类方法和静态方法
Oct 24 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
一段php加密解密的代码
2007/07/16 PHP
PHP获取文件绝对路径的代码(上一级目录)
2011/05/29 PHP
php记录代码执行时间(实现代码)
2013/07/05 PHP
javascript some()函数用法详解
2014/11/13 PHP
php批量添加数据与批量更新数据的实现方法
2014/12/16 PHP
在JavaScript中实现命名空间
2006/11/23 Javascript
js下利用控制器载入对应脚本
2010/07/17 Javascript
jQuery判断iframe中元素是否存在的方法
2013/05/11 Javascript
向左滚动文字 js代码效果
2013/08/17 Javascript
Select标签下拉列表二级联动级联实例代码
2014/02/07 Javascript
js获得页面的高度和宽度的方法
2014/02/23 Javascript
js判断上传文件类型判断FileUpload文件类型代码
2014/05/20 Javascript
JS判断移动端访问设备并加载对应CSS样式
2014/06/13 Javascript
jquery合并表格中相同文本的相邻单元格
2015/07/17 Javascript
js实现将选中内容分享到新浪或腾讯微博
2015/12/16 Javascript
js数组的五种迭代方法及两种归并方法(推荐)
2016/06/14 Javascript
NodeJS实现图片上传代码(Express)
2017/06/30 NodeJs
Node.js简单入门前传
2017/08/21 Javascript
详解vue mint-ui源码解析之loadmore组件
2017/10/11 Javascript
基于vue循环列表时点击跳转页面的方法
2018/08/31 Javascript
js遍历详解(forEach, map, for, for...in, for...of)
2019/08/28 Javascript
浅谈Python 的枚举 Enum
2017/06/12 Python
基于树莓派的语音对话机器人
2019/06/17 Python
Python实现自定义读写分离代码实例
2019/11/16 Python
Python Des加密解密如何实现软件注册码机器码
2020/01/08 Python
Python3交互式shell ipython3安装及使用详解
2020/07/11 Python
python 深度学习中的4种激活函数
2020/09/18 Python
《秋姑娘的信》教学反思
2014/02/28 职场文书
《风娃娃》教学反思
2014/04/19 职场文书
室内设计专业自荐信
2014/05/31 职场文书
《我爱祖国》演讲稿1000字
2014/09/26 职场文书
2014年园林绿化工作总结
2014/12/11 职场文书
小学优秀教师事迹材料
2014/12/16 职场文书
自愿离婚协议书2015
2015/01/26 职场文书
团委工作总结2015
2015/04/02 职场文书
学困生转化工作总结
2015/08/13 职场文书