Python基础知识-pycharm版-第四天(1)

一、序列解包

1.序列解包可以用于元组、列表、字典。序列解包可以让我们方便的对多个变量赋值。

>>> x,y,z=(20,30,10)

>>> x 20

>>> y 30

>>> z 10

>>> (a,b,c)=(9,8,10)

>>> a

9

>>> [a,b,c]=[10,20,30]

>>> a 10

>>> b

20

2.序列解包用于字典时,默认是对“键”进行操作; 如果需要对键值对操作,则需要使用 items();如果需要对“值”进行操作,则需要使用 values();

>>> s = {'name':'gaoqi','age':18,'job':'teacher'}

>>> name,age,job=s                                               #默认对键进行操作

>>> name'name' >>> name,age,job=s.items()       #对键值对进行操作

>>> name ('name', 'gaoqi')

>>> name,age,job=s.values()                                #对值进行操作

>>> name 'gaoqi

二、表格数据使用字典和列表存储,并实现访问

r1 = {"name":"高小一","age":18,"salary":30000,"city":"北京"}
r2 = {"name":"高小二","age":19,"salary":20000,"city":"上海"}
r3 = {"name":"高小五","age":20,"salary":10000,"city":"深圳"}
tb = [r1,r2,r3]
#获得第二行的人的薪资
print(tb[1].get("salary"))
#打印表中所有的的薪资
for i in range(len(tb)): # i -->0,1,2
print(tb[i].get("salary"))
#打印表的所有数据
for i in range(len(tb)):
print(tb[i].get("name"),tb[i].get("age"),tb[i].get("salary"),tb[i].get("city"))

三、字典核心底层原理(重要)

字典对象的核心是散列表。散列表是一个稀疏数组(总是有空白元素的数组),数组的 每个单元叫做 bucket。每个 bucket 有两部分:一个是键对象的引用,一个是值对象的引 用。 由于,所有 bucket 结构和大小一致,我们可以通过偏移量来读取指定 bucket

Python基础知识-pycharm版-第四天(1)

 

四、将一个键值对放进字典的底层过程

>>> a = {}

>>> a["name"]="gaoqi"

假设字典 a 对象创建完后,数组长度为 8:

Python基础知识-pycharm版-第四天(1)

 

 

我们要把”name”=”gaoqi”这个键值对放到字典对象 a 中,首先第一步需要计算 键”name”的散列值。Python 中可以通过hash()来计算。

>>> bin(hash("name"))

'-0b1010111101001110110101100100101'

由于数组长度为 8,我们可以拿计算出的散列值的最右边 3 位数字作为偏移量,即 “101”,十进制是数字 5。我们查看偏移量 5,对应的 bucket 是否为空。如果为空,则 将键值对放进去。如果不为空,则依次取右边 3 位作为偏移量,即“100”,十进制是数字4。再查看偏移量为 4 的 bucket 是否为空。直到找到为空的 bucket 将键值对放进去。流程图如下:

Python基础知识-pycharm版-第四天(1)

五、扩容

python 会根据散列表的拥挤程度扩容。

“扩容”指的是:创造更大的数组,将原有内容 拷贝到新数组中。

接近 2/3,数组就会扩容。

上一篇:Ceph 之RGW Pub-Sub Module


下一篇:SequoiaDB巨杉数据库S3实例的连接