字典是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 >>>上面的操作在实际上还是挺有用的。