python cookbook 学习笔记 第一章 数据结构和算法(16)从字典中提取子集

  • 从字典中提取子集
  • 问题
    • 想要构造一个字典,它是另外一个字典的子集
  • 解决方案:
    • 最简单的方式是字典推导。比如:
prices = {
    "ACME": 45.23,
    "AAPL": 612.78,
    "IBM": 205.55,
    "HPQ": 37.20,
    "FB": 10.75
}

p1 = {key: value for key, value in prices.items() if value > 200}
print(p1)  # {'AAPl': 612.78, 'IBM': 205.55}
tech_names = {"AAPL", "IBM", "HPQ", "MSFT"}
p2 = {key: value for key, value in prices.items() if key in tech_names}
print(p2)  # {'AAPL': 612.78, 'IBM': 205.55, 'HPQ': 37.2}
  • 讨论: 大多数情况下字典推导能做到的,通过创建一个元组序列然后把他传给 dict() 函数也能实现。比如:
p1 = dict((key,value) for key, value in prices.items() if value > 200)
print(p1)
  • 但是,字典推导方式表意更清晰,并且时间上也会运行的更快些(在这个例子中,实际测试几乎比dict()函数 方式快整一倍)。
  • 有时候完成同一件事会有多种方式。比如第二个例子也可以这样写:
teach_names = {"AAPL", "IBM", "HPQ", "MSFT"}
p2 = {key:prices[key] for key in prices.keys() & tech_names}
  • 但是,运行时间测试结果显示这种方案大概比第一种方案慢1.6倍。如果对程序运行性能要求比较高的话,需要 花点时间去做计时测试。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值