字典元素由键(Key)和对应的值(Value)两部分组成。
在 Python 中,字典(Dictionary)是一种无序的数据结构,用于存储键-值对(Key-Value Pairs)。字典元素由键(Key)和对应的值(Value)两部分组成。具体来说,字典的键通常是字符串(String)或数字(Number),而值可以是任何类型的 Python 对象,包括字符串、数字、列表(List)、元组(Tuple)、集合(Set)和甚至是其他字典。
字典的学习
1、字典类型简介
字典(dict)是存储key/value数据的容器,也就是所谓的map、hash、关联数组。无论是什么称呼,都是键值对存储的方式。
2、字典元素的顺序改变
因为元素存储到dict的时候,都经过hash()计算,且存储的实际上是key对应的hash值,所以dict中各个元素是无序的,或者说无法保证顺序。所以,遍历dict得到的元素结果也是无序的。无序是理论上的。但是在python 3.7中,已经保证了python dict中元素的顺序和插入顺序是一致的。
3、字典和列表的比较
python中list是元素有序存储的序列代表,dict是元素无序存储的代表。它们都可变,是python中最灵活的两种数据类型。
但是:dict的元素检索、增删改速度快,不会随着元素增多、减少而改变。但缺点是内存占用大list的元素检索、增删改速度随着元素增多会越来越慢(当然实际影响并没有多大),但是内存占用小,换句话说,dict是空间换时间,list是时间换空间。
其实从dict和list的数据结构上很容易可以看出dict要比list占用的内存大。不考虑存储元素的实际数据空间,list存储每个元素只需一个指针***8字节(64位机器)即可保存,而dict至少需要24字节(64位机器),不仅如此,hash表结构中每个hash桶基本上会空余1/3以上的空间。