假设我在 python 中有一个字典,我按值对键进行排序,如下所示
my_dict = {'a':5, 'b':4, 'c':6, 'd':3, 'e':2}
sorted_list = sorted(my_dict, key=my_dict.get)
sorted_list
['e', 'd', 'b', 'a', 'c']
这很好用,但是如果我的字典中有冲突(关于值)
my_dict = {'a':5, 'b':4, 'c':5, 'd':3, 'e':2, 'f':4, 'g':3}
sorted_list = sorted(my_dict, key=my_dict.get)
sorted_list
['e', 'd', 'g', 'b', 'f', 'a', 'c']
在我看来,如果出现重复,列表按字典中的顺序(数字顺序或插入顺序,而不是排序顺序)排序。我可以假设它适用于所有情况吗?
EDIT1:我的键将是整数,如果值发生冲突,我希望结果键按它们的值排序(最高优先)
EDIT2:添加以下参数有助于我的问题。但是,就我而言,我希望值按升序排序,但键按降序排序。以下将导致降序 key=lambda x: (x[1],x[0])