需求
给你一个条件,从已给字典中构造一个符合条件的新字典,为原字典的子集。
解决方案
使用字典推导式:
1 | prices = { |
案例
1 | # 需求:输出phone_bill中每月不为'0.00'的项目 |
思考
大多数情况下字典推导能做到的,通过创建一个元组序列然后把它传给 dict() 函数也能实现。比如:1
p1 = dict((key, value) for key, value in prices.items() if value > 200)
但是,字典推导方式表意更清晰,并且实际上也会运行的更快些 (在这个p1中,实际测试几乎比 dcit() 函数方式快整整一倍)。
有时候完成同一件事会有多种方式。比如,p2程序也可以像这样重写:1
2
3# Make a dictionary of tech stocks
tech_names = { 'AAPL', 'IBM', 'HPQ', 'MSFT' }
p2 = { key:prices[key] for key in prices.keys() & tech_names }
但是,运行时间测试结果显示这种方案大概比第一种方案慢1.6倍。
所以,完成一个需求,方案并不是唯一的,也并没有最完美的,只有更好的解决方案,如果对程序运行性能要求比较高的话,这就需要花点时间去做计时测试了。