正在创建新字典,以便先对关键字进行排序,然后根据值进行排序



我知道是惰性排序的。我正在尝试制作一个新的字典,在"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)]}

最新更新