ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

Python operator.itemgetter()

2021-12-02 10:33:20  阅读:228  来源: 互联网

标签:rows uid Python lname fname 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))

输出:

2
(2, 1)

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}]


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)]


三、讨论

标签:rows,uid,Python,lname,fname,operator,itemgetter
来源: https://www.cnblogs.com/keye/p/15632092.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有