我知道是惰性排序的。我正在尝试制作一个新的字典,在"Key"上按字母顺序排序,然后对元组中最后一个元素的值进行排序。
当前词典:
D1 = {'Lakers': [('James','PG',23,2), ('Davis', 'PF', 3, 3), ('Johnson', 'PG', 33,
1)], 'Pistons': [('Billips', 'PG', 1, 1 ), ('Wallace', 'C', 3, 3)], 'Hawks':
[('Young', 'PG', 11, 1), ('Collins', 'PF', 3, 2)] }
我想要的词典:
New_D1 = { 'Hawks':[('Collins', 'PF', 3, 2),('Young', 'PG', 11, 1)], 'Lakers': [('Davis', 'PF', 3, 3),('James','PG',23,2), ('Johnson', 'PG', 33, 1)], 'Pistons': [('Wallace', 'C', 3, 3),('Billips', 'PG', 1, 1 ) ] }
我当前要排序的代码是:
New_D1 = dict(sorted(D1.items()))
这将创建一个新字典(new_D1(,并且只对键进行排序。我现在需要对元组列表的最后一个元素中的值进行排序。
您可以在已经进行的分类之上进行理解:
>>> {k: sorted(v, key=lambda t: -t[-1]) for k, v in sorted(D1.items())}
{'Hawks': [('Collins', 'PF', 3, 2), ('Young', 'PG', 11, 1)], 'Lakers': [('Davis', 'PF', 3, 3), ('James', 'PG', 23, 2), ('Johnson', 'PG', 33, 1)], 'Pistons': [('Wallace', 'C', 3, 3), ('Billips', 'PG', 1, 1)]}
您需要构建一个新的dict,通过对键进行排序来插入,并添加同样排序的值
result ={}
for key, val in sorted(D1.items()):
result[key] = sorted(val, key=lambda x: x[-1], reverse=True)
您可以通过dict理解内联修改,而不使用分层dict
D1 = {key: sorted(val, key=lambda x: x[-1], reverse=True) for key, val in sorted(D1.items())}
您可以使用itemgetter
>>> from operator import itemgetter
>>> {k:sorted(v, key=itemgetter(3)) for k,v in New_D1.items()}
{'Hawks': [('Young', 'PG', 11, 1), ('Collins', 'PF', 3, 2)],
'Lakers': [('Johnson', 'PG', 33, 1), ('James', 'PG', 23, 2), ('Davis', 'PF', 3, 3)],
'Pistons': [('Billips', 'PG', 1, 1), ('Wallace', 'C', 3, 3)]}
{k: sorted(v, key=lambda x: x[:-1]) for k,v in sorted(D1.items(), key=lambda x: x[0])}
它非常简单,甚至不需要上面提出的lambda函数:
{k: sorted(v) for k,v in D1.items()}
这会产生你想要的结果:
{'Lakers': [('Davis', 'PF', 3, 3),
('James', 'PG', 23, 2),
('Johnson', 'PG', 33, 1)],
'Pistons': [('Billips', 'PG', 1, 1), ('Wallace', 'C', 3, 3)],
'Hawks': [('Collins', 'PF', 3, 2), ('Young', 'PG', 11, 1)]}