使用sorted可对可迭代对象进行非就地排序并返回排序结果(Python默认就地算法返回non,如list.sort())
sorted(iterable, cmp=None, key=None, reverse=False)
由于字典无序,最好的结果是通过sorted返回字典排序结果
选择lambda函数作为key参数,主要作用为传入可迭代对象的元素并返回一个比较依据来与下一个元素经过key函数处理所得的比较依据进行比较(注意cmp和key两个参数,不要弄混)
要注意的是可能与底层逻辑有关,字典虽然是可迭代对象,但通常情况下sorted只能对字典进行这样的迭代排序
trade = {
"1交通花费": 200,
"2饮食花费": 1000,
"3学习花费": 400
}
print(sorted(trade,key = lambda x:x[0],reverse=False))
#输出结果: ['1交通花费', '2饮食花费', '3学习花费']
结合数据结构相关知识可以推测出字典的底层实现高效存储了字典中的key值(猜的,毕竟抽象出底层框架有利于学习,有机会接触到了再更新知识结构)并交给sorted进行迭代。此时如果硬要拆包(不是cs那个)会出现以下错误
for k,y in sorted(trade,key = lambda x:x[0],reverse=False):
pass
ValueError: too many values to unpack (expected 2)
在得知以上情况后可得出以下代码(程序员的事能叫抄么=。。=)
for k,y in sorted(trade.items(),key = lambda x:(x[0],x[1]),reverse=False):
pass
for k,y in sorted(trade.items(),key = lambda x:x[0],reverse=False):
pass
使用dict.items()将字典内容转化为元素为元组的字典并获取结果