Python对字典中的键值排序

字典是Python的另一种有序的可变数据结构,且可存储任意类型对象。字典是一种键值对的数据容器,每个键值(key:value)对用冒号(:)分割,每个对之间用逗号(,)分割,整个字典包括在花括号“{}”中。键和值两者一一对应,与表不同的是,词典的元素没有顺序,不能通过下标引用元素。字典是通过键来引用。

字典中的键必须是唯一的同时不可变的,值则没有限制。但其中的键:值的关系是hash,所以键打印出来其实是无序的。

>>> D = {'a': 97, 'b': 98, 'c': 99, 'd': 100}
>>> for key in D:
...     print key, '==>', D[key]
...
a ==> 97
c ==> 99
b ==> 98
d ==> 100
>>>

实际上有不少需求,键要求是有序输出,或有序来处理,这个时候就需要使用sorted()等方式按键来排序:

>>> D = {'a': 97, 'b': 98, 'c': 99, 'd': 100}
>>> for key in sorted(D):
...     print key, '==>', D[key]
...
a ==> 97
b ==> 98
c ==> 99
d ==> 100

或者先将键来排序

>>> D = {'a': 97, 'b': 98, 'c': 99, 'd': 100}
>>> keys = list(D.keys())
>>> keys.sort()
>>> keys
['a', 'b', 'c', 'd']
>>> for key in keys:
...     print key,'==>', D[key]
...
a ==> 97
b ==> 98
c ==> 99
d ==> 100
>>>

或者使用sorted()

>>> D = {'a': 97, 'b': 98, 'c': 99, 'd': 100}
>>> keys = sorted(D.keys())
>>> keys
['a', 'b', 'c', 'd']
>>> for key in keys:
...     print key,'==>',D[key]
...
a ==> 97
b ==> 98
c ==> 99
d ==> 100
>>>
上面的操作在实际上还是挺有用的。 


猜你喜欢

转载自blog.csdn.net/Jerry_1126/article/details/80725700