参考:
https://www.cnblogs.com/zhoufankui/p/6274172.html
https://www.cnblogs.com/sunshineyang/p/7234850.html
operator模块提供的itemgetter函数用于获取对象的哪些维的数据,参数为一些序号,即需要获取的数据在对象中的序号。也可以理解成把一个对象看做是几个域的集合,并给这几个域编号。最终每个域都有一个数字与之对应。值得注意是,operator.itemgetter函数获取的不是值,而是定义了一个函数,通过该函数作用到对象上才能获取值。
例如有 dic ={‘apple’:’2’,’car’:’1’,’ban’:’3’},我们说operator.itemgetter(0)得到的域是第一维对应的序号,而operator.itemgetter(1)得到的是第2维对应的序号。我们借助sorted函数来说明,只要明白sorted函数是用来排序的即可。具体的参数的意义在下一小节中可以看到。
>>> dic ={'apple':'2','car':'1','ban':'3'}
>>> dic
{'ban': '3', 'car': '1', 'apple': '2'}
>>> type(dic)
'dict'>
# 将dic转为迭代器
>>> dic2 = dic.iteritems()
>>> dic2
0x7f70ee860838>
>>> list(dic2)
[('ban', '3'), ('car', '1'), ('apple', '2')]
# 使用第二维来对dic降序排序,也就是按数字那一属性来排序
>>> s1 = sorted(dic.iteritems(),key = operator.itemgetter(1),reverse=True)
>>> s1
[('ban', '3'), ('apple', '2'), ('car', '1')]
#使用第一维来对dic降序排序,也就是按字母那一属性来排序
>>> s2 = sorted(dic.iteritems(),key = operator.itemgetter(0),reverse=True)
>>> s2
[('car', '1'), ('ban', '3'), ('apple', '2')]
# 有3个域的list
>>> a = [('cat','A',5),('apple','C',2),('banana','B',1)]
>>> type(a)
'list'>
# 按照数字从小到大排
>>> sorted(a,key=operator.itemgetter(2))
[('banana', 'B', 1), ('apple', 'C', 2), ('cat', 'A', 5)]
# 按照单字母从小到大排
>>> sorted(a,key=operator.itemgetter(1))
[('cat', 'A', 5), ('banana', 'B', 1), ('apple', 'C', 2)]
# 按照字符串比较从小到大排
>>> sorted(a,key=operator.itemgetter(0))
[('apple', 'C', 2), ('banana', 'B', 1), ('cat', 'A', 5)]
该函数的原型为sorted(iterable[, cmp[, key[, reverse]]])
参数解释:
(1)iterable指定要排序的list或者iterable;
(2)cmp为函数,接受一个函数(有两个参数),指定排序时进行比较的函数,可以指定一个函数或者lambda函数;
(3)key为函数,指定待排序元素的哪一项进行排序,它接受一个函数,而且该函数只有一个参数。
(4)reverse参数是一个bool变量,表示进行升序还是降序排列,默认为false(升序排列),定义为True时将按降序排列。
可以在operator.itemgetter那里看到具体的应用。