开发工具与关键技术:Python IDEL、Python
作者:曾浩源
撰写时间:2019年07月17日
python的元组、列表、字典数据类型是python的数据结构。
一、元组 tuple 用小括号“( )”表示
首先元组,个人觉得元组就像java中的数组。
列表属于可变序列,可以任意修改列表中的元素。元组属于不可变序列,不能修改元组中的元素。因此,元组没有增加元素、修改元素、删除元素相关的方法。
1、元组的创建
通过()创建元组。小括号可以省略。
a = (1,2,3,4,5)或者a = 1,2,3,4,5
2、如果元组只有一个元素, 则必须后面加逗号。
这是因为解释器会把(1)解释为整数 1, (1,)解释为元组。
所以看着是小括号()表示元组,实际上最主要的是逗号。
最后:tuple的官方内置函数可用dir(tuple)与help(tuple) 命令进行查看。
总结:使用元组时最重要的一点是“一旦生成,就不可变了”。
二、列表 list 用中括号“[ ]”表示
列表就像java里的collection,所具有的特性也要比元组更多,更灵活,其character总结如下:
1.任意对象的有序集合
列表是一组任意类型的值,按照一定顺序组合而成的
2.通过偏移读取
组成列表的值叫做元素(Elements)。每一个元素被标识一个索引,第一个索引是0, 序列的功能都能实现
3.可变长度,异构以及任意嵌套
列表中的元素可以是任意类型,甚至是列表类型,也就是说列表可以嵌套
4.可变的序列
支持索引、切片、合并、删除等等操作,它们都是在原处进行修改列表
5.对象引用数组
列表可以当成普通的数组,每当用到引用时,Python总是会将这个引用指向一个 对象,所以程序只需处理对象的操作。
列表是内置可变序列,是包含多个元素的有序连续的内存空间。列表定义的标准语法格式:
a = [10,20,30,40]其中,10,20,30,40 这些称为:列表 a 的元素。
列表中的元素可以各不相同,可以是任意类型。比如:a = [10,20,‘abc’,True]
方法 作用 描述
list.append(a) | 添加元素 | 将元素a添加到列表list尾部 |
---|---|---|
list.extend(list1) | 添加元素 | 将列表list1的所有元素添加到list尾部 |
list.insert(index,a) | 添加元素 | 在列表list指定位置index处插入元素a |
list.remove(a) | 删除元素 | 在列表list中删除首次出现的指定元素a |
list.pop([index]) | 删除(取出)元素 | 删除并返回列表list指定位置index处的元素,默认最后一个元素 |
list.clear() | 清空列表 | 删除列表所有元素,并不是删除列表对象 |
list,index(a) | 访问元素 | 返回第一个a的索引位置,若不存在抛异常 |
list.count(a) | 计算元素个数 | 返回指定元素a在列表list出现的次数 |
len(list) | 列表长度 | 返回列表list中包含元素的个数 |
list.reverse() | 翻转列表 | 将列表list的元素原地翻转 |
list.sort() | 列表排序 | 将列表list的元素原地排序 |
list.copy() | 浅拷贝 | 返回列表list对象的浅拷贝 |
这是一些比较常用的方法,除了这些还有一个很常用的方法,叫切片(分片)
利用索引值获取列表,如:
根据索引获取列表里的元素,多维列表也可以。
当冒号两边都没有数字,则相当于拷贝列表。
list的官方内置函数可用dir(list)与help(list) 命令进行查看。
元组和列表总结:
tuple()可以接收列表、字符串、其他序列类型、迭代器等生成元组。
list()可以接收元组、字符串、其他序列类型、迭代器等生成列表。
-
元组和list相比
- 1.比列表操作速度快
- 2.对数据“写保护“
- 3.可用于字符串格式化中
- 4 .可作为字典的key
三、字典 dict 用大括号“{key,value}”表示
字典是“键值对”的无序可变序列,字典中的每个元素都是一个“键值对”。
包含: “键对象”和“值对象”。可以通过“键对象”实现快速获取、删除、更新对应的“值对象”。
列表中我们通过“下标数字”找到对应的对象。
字典中通过“键对象”找到对应的“值对象”。
“键”是任意的不可变数据,比如:整数、浮点数、字符串、元组。
但是:列表、字典、集合这些可变对象,不能作为“键”。
并且“键”不可重复。“值”可以是任意的数据,并且可重复。
一个字典的定义方式:a = {‘name’:‘小明’,‘age’:20,‘job’:‘学生’}
1.通过键而不是偏移量来读取
字典就是一个关联数组,是一个通过关键字索引的对象的集合,使用键-值( key-value)进行存储,查找速度快
2.任意对象的无序集合
字典中的项没有特定顺序,以“键”为象征
3.可变长、异构、任意嵌套
同列表,嵌套可以包含列表和其他的字典等
4.属于可变映射类型
因为是无序,故不能进行序列操作,但可以在远处修改,通过键映射到值。字典是 唯一内置的映射类型(键映射到值的对象)
5.对象引用表
字典存储的是对象引用,不是拷贝,和列表一样。字典的key是不能变的,list 不能作为key,字符串、元祖、整数等都可以
-
和list比较,dict有以下几个特点:
- 1.查找和插入的速度极快,不会随着key的增加而增加
- 2.需要占用大量的内存,内存浪费多 而list相反:
- 1.查找和插入的时间随着元素的增加而增加
- 2.占用空间小,浪费内存很少
所以,dict是用空间来换取时间的一种方法
用法总结:
- 键必须可散列
(1) 数字、字符串、元组,都是可散列的。
(2) 自定义对象需要支持下面三点:
1支持 hash()函数
2支持通过__eq__()方法检测相等性。
3若 a==b 为真,则 hash(a)==hash(b)也为真。 - 字典在内存中开销巨大,典型的空间换时间。
- 键查询速度很快
- 往字典里面添加新建可能导致扩容,导致散列表中键的次序变化。因此,不要在遍 历字典的同时进行字典的修改。