实际案列:
某班数学成绩以字典形式存储为:{'Tom': 88, 'Jack': 90, 'Rose': 100...},想要根据成绩来进行排序。
- 方法一:
可以通过zip
函数,将字典转化为一个元组:
In [1]: from random import randint
In [2]: s = {x: randint(60, 100) for x in 'ABCDEF'}
In [3]: s
Out[3]: {'A': 87, 'B': 99, 'C': 62, 'D': 67, 'E': 97, 'F': 89}
In [4]: s.keys()
Out[4]: ['A', 'C', 'B', 'E', 'D', 'F']
In [5]: s.values()
Out[5]: [87, 62, 99, 97, 67, 89]
# 小技巧:可以使用s.iterkeys()和s.itervalues()来提高程序的运行效率
In [6]: zip(s.itervalues(), s.iterkeys())
Out[6]: [(87, 'A'), (62, 'C'), (99, 'B'), (97, 'E'), (67, 'D'), (89, 'F')]
In [7]: sorted(zip(s.itervalues(), s.iterkeys()))
Out[7]: [(62, 'C'), (67, 'D'), (87, 'A'), (89, 'F'), (97, 'E'), (99, 'B')]
- 方法二:
使用内置的sorted
函数的key
参数,来指定排序的依据。默认的
sorted
函数用在字典中,仅对字典的键进行排序,而不考虑值。
In [8]: sorted(s)
Out[8]: ['A', 'B', 'C', 'D', 'E', 'F']
In [9]: sorted(s.iteritems(), key=lambda x: x[1])
Out[9]: [('C', 62), ('D', 67), ('A', 87), ('F', 89), ('E', 97), ('B', 99)]