从字典中提取子集

欢迎猛击个人博客悟の迹【http://chihweihsu.com】更多精彩等着你


需求

给你一个条件,从已给字典中构造一个符合条件的新字典,为原字典的子集。

解决方案

使用字典推导式:

prices = {
    'ACME': 45.23,
    'AAPL': 612.78,
    'IBM': 205.55,
    'HPQ': 37.20,
    'FB': 10.75
}
# Make a dictionary of all prices over 200
p1 = {key: value for key, value in prices.items() if value > 200}
# Make a dictionary of tech stocks
tech_names = {'AAPL', 'IBM', 'HPQ', 'MSFT'}
p2 = {key: value for key, value in prices.items() if key in tech_names}

案例

# 需求:输出phone_bill中每月不为'0.00'的项目
"phone_bill" : [
        {
            "bill_zengzhifei" : "0.00",
            "bill_qita" : "0.00",
            "bill_package" : "46.00",
            "bill_ext_sms" : "0.20",
            "bill_daishoufei" : "0.00",
            "bill_ext_data" : "0.00",
            "bill_ext_calls" : "0.00"
        },
        {
            "bill_zengzhifei" : "0.00",
            "bill_qita" : "0.00",
            "bill_package" : "46.00",
            "bill_ext_sms" : "0.60",
            "bill_daishoufei" : "0.00",
            "bill_ext_data" : "15.62",
            "bill_ext_calls" : "4.18"
        },
        {
            "bill_zengzhifei" : "0.00",
            "bill_qita" : "0.00",
            "bill_package" : "56.00",
            "bill_ext_sms" : "0.30",
            "bill_daishoufei" : "0.00",
            "bill_ext_data" : "9.36",
            "bill_ext_calls" : "7.03"
        },
        {
            "bill_zengzhifei" : "0.00",
            "bill_qita" : "0.00",
            "bill_package" : "46.00",
            "bill_ext_sms" : "0.30",
            "bill_daishoufei" : "0.00",
            "bill_ext_data" : "0.00",
            "bill_ext_calls" : "0.00"
        },
        {
            "bill_zengzhifei" : "0.00",
            "bill_qita" : "0.00",
            "bill_package" : "10.58",
            "bill_ext_sms" : "0.00",
            "bill_daishoufei" : "0.00",
            "bill_ext_data" : "0.00",
            "bill_ext_calls" : "0.00"
        }
    ]

# 处理逻辑
for cursor in xrange(0,5):
     phone_bill_tmp = {key: value[:-1] for key, value in phone_bill[cursor].items() if value not in ['','0.00']}
     phone_bill.append(phone_bill_tmp)

# 结果
"phone_bill" : [
        {
            "bill_package" : "46.0",
            "bill_ext_sms" : "0.2"
        },
        {
            "bill_package" : "46.0",
            "bill_ext_sms" : "0.6",
            "bill_ext_data" : "15.6",
            "bill_ext_calls" : "4.1"
        },
        {
            "bill_package" : "56.0",
            "bill_ext_sms" : "0.3",
            "bill_ext_data" : "9.3",
            "bill_ext_calls" : "7.0"
        },
        {
            "bill_package" : "46.0",
            "bill_ext_sms" : "0.3"
        },
        {
            "bill_package" : "10.5"
        }
    ]

思考

大多数情况下字典推导能做到的,通过创建一个元组序列然后把它传给 dict() 函数也能实现。比如:

p1 = dict((key, value) for key, value in prices.items() if value > 200)

但是,字典推导方式表意更清晰,并且实际上也会运行的更快些 (在这个p1中,实际测试几乎比 dcit() 函数方式快整整一倍)。

有时候完成同一件事会有多种方式。比如,p2程序也可以像这样重写:

# 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倍。

所以,完成一个需求,方案并不是唯一的,也并没有最完美的,只有更好的解决方案,如果对程序运行性能要求比较高的话,这就需要花点时间去做计时测试了。


博文转载至我的个人博客网站--悟の迹,欢迎来访。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 174,589评论 25 709
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,268评论 19 139
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,295评论 4 61
  • 显现-练习——使用 我行,一切行,我行任之行 选好人,做对事 懂人事 体验价值从满足身边人的需求开始 日精进第...
    于英彬阅读 272评论 1 0
  • 那个平凡的女孩,正在接受岁月的洗礼。 2017年8月14日 上午小雨,下午晴 想南签完离婚协议后,就一个人在大街上...
    这孩子阅读 221评论 2 1