目录
序列
-
序列是一种数据存储方式,用来存储一系列的数据。在内存中,序列就是一块用来存放多个值的连续的内存空间。比如一个整数序列[10,20,30,40],可以这样示意表示:
-
由于Python中一切皆对象,在内存中实际是按照如下方式存储的:
a=[10,20,30,40]
-
从图示中,我们可以看出序列中存储的是整数对象的地址(id),而不是整数对象(的值)(value)。
-
Python中常用序列结构有:
字符串、列表、元组、字典、集合
列表
列表简介
- 列表:用于存储任意数目、任意类型的数据集合
- 列表是内置可变序列,是包含多个元素的有序连续的内存空间。列表定义的语法格式是:
a=[10,20,30,40]
其中,10,20,30,40这些称为列表a的元素。 - 列表中的元素可以互不相同,可以是任意类型。比如:
a=[10,20,’abc’,True]
列表对象的常用方法总结如下:
方法 | 要点 | 描述 |
list.append(x) | 增加元素 | 将元素x增加到列表list尾部 |
list.extend(alist) | 增加元素 | 将列表alist所有元素加到列表list尾部 |
list.insert(index,x) | 增加元素 | 在列表list指定位置index处插入元素x |
list.remove(x) | 删除元素 | 在列表list中删除首次出现的指定元素x |
list.pop([index]) | 删除元素 | 删除并返回列表list指定位置index处的元素,默认是最后一个元素 |
list.clear() | 删除所有元素 | 删除列表所有元素,而不是删除列表对象 |
list.index(x) | 访问元素 | 返回第一个x的索引位置,若不存在x元素,抛出异常 |
list.count(x) | 计数 | 返回指定元素x在列表list中出现次数 |
len(list) | 列表长度 | 返回列表中包含元素个数 |
list.reverse() | 翻转列表 | 所有元素原地翻转 |
list.sort() | 排序 | 所有元素原地排序 |
list.copy() | 浅拷贝 | 返回列表对象的浅拷贝 |
Python的列表大小可变,根据需要随时增加或缩小。
列表创建
基本语法[]创建
>>>a=[10,20,’gaoqi’,’sxt’]
>>>a=[] #创建一个空的列表对象
list()创建
使用list()可以将任何可迭代的数据转化为列表
>>>a=list() #创建一个空的列表对象
>>>a=list(range(10))
>>>a
[0,1,2,3,4,5,6,7,8,9]
>>>a=list(‘gaoqi,sxt’)
>>>a
[‘g’,’a’,’o’,’q’,’i’,’,’,’s’,’x’,’t’]
range()创建整数列表
range()可以帮助我们非常方便的创建整数列表,这在开发中极其有用。语法格式为:
range([start],end,[step])
start:可选,表示起始数字
end:必选,表示结尾数字
step:可选,表示步长,默认为1
python3中的range()返回的是一个range对象,而不是列表。我们需要通过list()方法将其转化为列表对象。
典型示例如下:
>>>list(range(3,15,2))
[3,5,7,9,11,13]
>>>list(range(15,3,-1))
[15,14,13,12,11,10,9,8,7,6,5,4]
>>>list(range(3,-10,-1))
[3,2,1,0,-1,-2,-3,-4,-5,-6,-7,-8,-9]
推导式生成列表
使用列表推导式可以非常方便的创建列表,在开发中经常用到。但是,由于涉及到for循环和if语句。在此,仅做基本介绍。在我们控制语句后面,会详细讲解更多关于列表推导式的细节。
>>>a=[x*2 for x in range(5)] #循环创建多个元素
>>>a
[0,2,4,6,8]
>>>a=[x*2 for x in range(100) if x%9==0] #通过if语句过滤元素
[0,18,36,4,72,90,108,126,144,162,180,198]
该段代码等价于:
>>>b=[]
>>>for x in range(100):
if x%9==0:
b.append(x*2)
>>>b
列表_元素的5种添加方式_效率问题
列表元素的增加与删除
当列表增加和删除元素时,列表会自动进行内存管理,大大减少负担。但这个特点涉及列表元素的大量移动,效率较低。除非必要,我们一般只在列表的尾部增加元素或者删除元素,这会大大提高效率。
append()方法
原地修改列表对象,是真正的列表尾部添加新的元素,速度最快,也最实用。
>>>a=[10,20]
>>>a
[10,20]
>>>a.append(30)
>>>a
[10,20,30]
+运算符操作
并不是真正的尾部添加元素,而是新创建一个对象。将原列表的元素和新列表的元素依次复制到新的列表对象中。这样,会涉及大量的复制操作,对于操作大量元素不建议使用。
>>>a=[20,40]
>>>id(a)
46016072
>>>a=a+[50]
>>>id(a)
46015432
通过如上操作,我们可以发现变量a的地址发生了变化,也就是创建了新的列表对象。
extend()方法
将目标列表的所有元素添加到本列表的尾部,属于原地操作,不创建新的列表对象。
>>>a=[20,40]
>>>id(a)
46016072
>>>a.extend([50,60])
>>>id(a)
46016072
insert()插入元素
使用insert()方法将指定元素插入到列表对象的任意指定位置。这样会让插入位置后面的所有元素进行移动,会影响处理速度。涉及大量元素时,尽量避免使用。类似发生这种移动的函数还有:remove()、pop()、del(),它们在删除非尾部元素时也会发生操作位置后面的元素的移动。
>>>a=[10,20,30]
>>>a.insert(2,100)
>>>a
[10,20,100,30]
乘法扩展
使用乘法扩展列表,生成一个新列表,新列表元素是原列表元素的多次重复。
>>>a=[‘sxt’,100]
>>>b=a*3
>>>a
[‘sxt’,100]
>>>b
[‘sxt’,100,’sxt’,100,’sxt’,100]
适用于乘法操作的,还有:字符串、元组。例如:
>>>c=’sxt’
>>>c*3
‘sxtsxtsxt’
列表_元素删除的3种方式_删除本质是数组元素拷贝
Del删除
删除列表指定位置的元素
>>>a=[10,20,30]
>>>del a[1]
>>>a
[10,30]
pop()方法
pop()删除并返回指定位置元素,如果未指定位置则默认操作列表最后一个元素。
>>>a=[10,20,30,40,50]
>>>a.pop()
50
>>>a
[10,20,30,40]
>>>a.pop(1)
20
>>>a
[10,30,40]
remove()方法
删除首次出现的指定元素,若不存在该元素抛出异常。
>>>a=[10,20,30,40,50,20,30,20,30]
>>>a.remove(20)
>>>a
[10,30,40,50,20,30,20,30]
>>>a.remove(100)
Error!
列表_元素的访问_元素出现次数统计_成员资格判断
列表元素访问和计数
通过索引直接访问元素
我们可以直接通过索引访问元素。索引的区间在0—len(list)-1这个范围。超过这个范围则会抛出异常。
>>>a=[10,20,30,40,50,20,30,20,30]
>>>a[2]
30
>>>a[10]
Error!
index()获得指定元素在列表中首次出现的索引
index()可以获取指定元素首次出现的索引位置。语法格式是:
index(value,[start,end])
其中,start和end指定搜索范围。
>>>a=[10,20,30,40,50,20,30,20,30]
>>>a.index(20)
1
>>>a.index(20,3)
5
count()获得指定元素在列表中出现次数
count()可以返回指定元素在列表中出现次数
>>>a=[10,20,30,40,50,20,30,20,30]
>>>a.count(20)
3
len()返回列表长度
len()返回列表长度,即列表中包含元素个数
>>>a=[10,20,30]
>>>len(a)
3
成员资格判断
判断列表中是否存在指定元素,我们可以使用count()方法,返回0则表示不存在,返回大于0则表示存在。但是,我们一般会使用更加简洁的in关键字来判断,直接返回True或者False。
>>>a=[10,20,30,40,50,20,30,20,30]
>>>20 in a
True
>>>100 not in a
True