zoukankan      html  css  js  c++  java
  • Python operator.itemgetter()


    一、问题

    对列表、元组、字典或(字典、元组组成的列表),根据属性值排序。



    二、解决方案

    1. 列表、元组、字典

    operator.itemgetter() 获取的不是值,而是定义一个函数,通过该函数作用到对象上才能获取值。

    from operator import itemgetter
    
    a = [1, 2, 3]
    b = itemgetter(1)       # 定义函数b,获取对象的第1个值
    c = itemgetter(1, 0)    # 定义函数c,获取对象的第1、0个值
    print(b(a))
    print(c(a))
    
    a = {'name': 'wangke', 'age':18, 'sex': 'man'}
    b = itemgetter('age')       
    c = itemgetter('name', 'age')    
    print(b(a))
    print(c(a))
    

    输出:

    2
    (2, 1)
    
    18
    ('wangke', 18)
    

    2. 字典列表

    operator.itemgetter() 可以排序这样的数据结构。

    数据:

    rows = [
        {'fname': 'Brian', 'lname': 'Jones', 'uid': 1003},
        {'fname': 'David', 'lname': 'Beazley', 'uid': 1002},
        {'fname': 'John', 'lname': 'Cleese', 'uid': 1001},
        {'fname': 'Big', 'lname': 'Jones', 'uid': 1004}
    ]
    

    根据字典字段排序:

    from operator import itemgetter
    
    rows_fname = sorted(rows, key=itemgetter('fname'))
    rows_uid = sorted(rows, key=itemgetter('uid'))
    print(rows_fname)
    print(rows_uid)
    

    输出:

    [{'fname': 'Big', 'lname': 'Jones', 'uid': 1004}, 
     {'fname': 'Brian', 'lname': 'Jones', 'uid': 1003}, 
     {'fname': 'David', 'lname': 'Beazley', 'uid': 1002}, 
     {'fname': 'John', 'lname': 'Cleese', 'uid': 1001}]
    
    [{'fname': 'John', 'lname': 'Cleese', 'uid': 1001}, 
     {'fname': 'David', 'lname': 'Beazley', 'uid': 1002}, 
     {'fname': 'Brian', 'lname': 'Jones', 'uid': 1003}, 
     {'fname': 'Big', 'lname': 'Jones', 'uid': 1004}]
    
    

    itemgetter()也可以用lambda代替,但是,itemgetter()会稍微快点。。

    rows_fname = sorted(rows, key=lambda r: r['fanme'])
    rows_uid = sorted(rows, key=lambda r: (r['fanme'], r['uid']))
    

    3. 元组列表

    from operator import itemgetter
    
    a = [('john', 'A', 15), ('jane', 'B', 12), ('dave', 'C', 10)]
    b = sorted(a, key=itemgetter(1))
    c = sorted(a, key=itemgetter(2))
    print(b)
    print(c)
    

    输出:

    [('john', 'A', 15), ('jane', 'B', 12), ('dave', 'C', 10)]
    [('dave', 'C', 10), ('jane', 'B', 12), ('john', 'A', 15)]
    


    三、讨论

    查找的元素个数相对比较小,用 nsmallest()nlargest()

    查找唯一的最大、最小值,用 max()min()

    查找元素个数与总的元素个数接近,通常先排序,然后再切片。sorted()



  • 相关阅读:
    CRMEB系统开发文档
    R语言︱LDA主题模型——最优主题...
    2018前端面试及答案
    开发流程
    uitramon 安装包
    scrapy 爬取时很多重复 及日志输出
    fake-useragent插件无法正常使用的问题
    区块链共识机制(一)
    Python Twisted 之 Deferred
    区块链的三大分支:公有链、联盟链和私有链
  • 原文地址:https://www.cnblogs.com/keye/p/15632092.html
Copyright © 2011-2022 走看看