op={'1':(1,0,6),'3':(0,45,8),'2':(2,34,10)} #原谅我随意的变量名
lp3=sorted(op.items(),key=operator.itemgetter(0),reverse=True)
print(lp3)
输出:[('3', (0, 45, 8)), ('2', (2, 34, 10)), ('1', (1, 0, 6))] #注意这里对字典op的key进行了排序
改变一下reverse看一下结果:
lp3=sorted(op.items(),key=operator.itemgetter(0),reverse=False)
输出:[('1', (1, 0, 6)), ('2', (2, 34, 10)), ('3', (0, 45, 8))] ##确认一下
接下来将key=operator.itemgetter(0)改为key=operator.itemgetter(1)
lp3=sorted(op.items(),key=operator.itemgetter(1),reverse=False) # 保持不变
输出:[('3', (0, 45, 8)), ('1', (1, 0, 6)), ('2', (2, 34, 10))]
同理再改变reverse的值我们得到:
lp3=sorted(op.items(),key=operator.itemgetter(1),reverse=True)
输出:[('2', (2, 34, 10)), ('1', (1, 0, 6)), ('3', (0, 45, 8))] #可以看出这里按照op的value---数组的第一个元素大小进行了排序
之前看了很多博客对operator.itemgetter()的介绍,他们只说,(引用于网络):
operator.itemgetter函数获取的不是值,而是定义了一个函数,通过该函数作用到对象上才能获取值。
operator.itemgetter函数 operator模块提供的itemgetter函数用于获取对象的哪些维的数据,参数为一些序号(即需要获取的数据在对象中的序号),下面看例子。 a = [1,2,3] >>> b=operator.itemgetter(1) //定义函数b,获取对象的第1个域的值 >>> b(a) 2 >>> b=operator.itemgetter(1,0) //定义函数b,获取对象的第1个域和第0个的值 >>> b(a) (2, 1) 要注意,operator.itemgetter函数获取的不是值,而是定义了一个函数,通过该函数作用到对象上才能获取值。
现在,我们明白了对于字典,这里说的第一个域指key,第二个域指value(若为数组。则指第一个元素)
自己试出来的结论,若有不当之处,不吝赐教。
另:引用处,侵删