python 字典和嵌套字典排序

正常字典的排序我们都知道,像这样

    a={100:1,101:0,102:2}
    b=sorted(a.items(),key=lambda x:x[1])

就会输出如下结果

[(101, 0), (100, 1), (102, 2)]

那如果是嵌套字典呢,比如

a={100:{'x':1,'y':2},101:{'x':2,'y':0},102:{'x':0,'y':3}}

实际上是类似的,我们只要理解了上面这个key的含义,lambda可以理解为一个函数,输出为x:x[1],即字典的第一个值,合起来就是以字典的第一个值作为key排序。所以嵌套字典就是按如下进行排序

    a={100:{'x':1,'y':2},101:{'x':2,'y':0},102:{'x':0,'y':3}}
    b=sorted(a.items(),key=lambda x:x[1]['x'])

x[1]表示{'x':1,'y':2},x[1]['x']就代表按'x'排序

输出如下

[(102, {'x': 0, 'y': 3}), (100, {'x': 1, 'y': 2}), (101, {'x': 2, 'y': 0})]

如果想要设置主序和次序,可以如下

key=lambda item: (-item[1][3], item[1][1], -item[1][2]))

就可以做到按键值3做主序,1做次序,2再次之排序了

你可能感兴趣的:(python)