列表是Python中使用最频繁也是最重要最灵活的一种数据结构。Python列表中的元素类型可以不同,可以存放各种各样的数据,比如:数字、字符串、函数、类、字典等,甚至还可以嵌套存放列表。
列表也是一种序列,可以通过索引获取列表中的元素。支持序列的各种操作。
十多年的会宁网站建设经验,针对设计、前端、开发、售后、文案、推广等六对一服务,响应快,48小时及时工作处理。成都全网营销的优势是能够根据用户设备显示端的尺寸不同,自动调整会宁建站的显示方式,使网站能够适用不同显示终端,在浏览器中调整网站的宽度,无论在任何一种浏览器上浏览网站,都能展现优雅布局与设计,从而大程度地提升浏览体验。创新互联公司从事“会宁网站设计”,“会宁网站推广”以来,每个客户项目都认真落实执行。
列表在创建的时候用[]
做标识。内部的元素用逗号进行分隔。
>>> lst1 = [] # 空列表
>>> lst2 = [1, 1, 2, 3, 5] # 列表中存放的全是数字
>>> lst3 = ['a', 'b', 'c'] # 列表中存放的全是字符
>>> lst4 = [1, 'a', '中'] # 列表中存放混合数据
>>> lst5 = ['red', 'green', 'blue'] # 列表中存放的全是字符串
>>> [x for x in range(5)]
[0, 1, 2, 3, 4]
>>> [x * x for x in range(10)]
[0, 1, 4, 9, 16, 25, 36, 49, 64, 81]
>>> [x*x for x in range(10) if x%3 == 0]
[0, 9, 36, 81]
>>> [[x, y] for x in range(3) for y in range(3)]
[[0, 0], [0, 1], [0, 2], [1, 0], [1, 1], [1, 2], [2, 0], [2, 1], [2, 2]]
>>> [[x, y] for x in range(5) for y in range(5) if y >= x]
[[0, 0], [0, 1], [0, 2], [0, 3], [0, 4], [1, 1], [1, 2], [1, 3], [1, 4], [2, 2], [2, 3], [2, 4], [3, 3], [3, 4], [4, 4]]
list函数可以将一个可迭代对象
转换成列表。
>>> print(list('Python'))
['P', 'y', 't', 'h', 'o', 'n']
参见可迭代对象
章节中的序列的拼接和重复
参见可迭代对象
章节中的序列的索引
参见可迭代对象
章节中的序列的切片
参见可迭代对象
章节中的可迭代对象的遍历
参见可迭代对象
章节中的成员资格检查
列表不同于字符串,是可以原地修改的。
可以通过索引的方式修改单个元素:
>>> lst = ['P', 'y', 't', 'h', 'o', 'n']
>>> lst[0] = 'J'
>>> lst
['J', 'y', 't', 'h', 'o', 'n']
可以通过切片的方式修改多个元素:
>>> lst = ['P', 'y', 't', 'h', 'o', 'n']
>>> lst[0:4] = 'Java'
>>> lst
['J', 'a', 'v', 'a', 'o', 'n']
>>> lst = ['P', 'y', 't', 'h', 'o', 'n']
>>> lst[0:4] = ['Java']
>>> lst
['Java', 'o', 'n']
通过索引删除单个元素
>>> lst = ['P', 'y', 't', 'h', 'o', 'n']
>>> del lst[0]
>>> print(lst)
['y', 't', 'h', 'o', 'n']
通过切片删除多个元素
>>> lst = ['P', 'y', 't', 'h', 'o', 'n']
>>> del lst[0:2]
>>> lst
['t', 'h', 'o', 'n']
>>> lst = ['P', 'y', 't', 'h', 'o', 'n']
>>> del lst
>>> lst
Traceback (most recent call last):
File "E:\studypy\tmp.py", line 3, in
print(lst)
NameError: name 'lst' is not defined. Did you mean: 'list'?
描述
在列表末尾添加一个元素,相当于a[len(a):] = [x]。
示例
lst = list('Python')
lst.append('1')
print(lst)
['P', 'y', 't', 'h', 'o', 'n', '1']
描述
用可迭代对象的元素扩展列表。相当于 a[len(a):] = iterable。
示例
lst = list('Python')
lst.extend('Java')
print(lst)
['P', 'y', 't', 'h', 'o', 'n', 'J', 'a', 'v', 'a']
lst1 = [1, 2, 3]
lst2 = [4, 5, 6]
lst1.extend(lst2)
print(lst1)
[1, 2, 3, 4, 5, 6]
描述
在指定位置插入1个元素。第一个参数是插入元素的索引,因此,a.insert(0, x) 在列表开头插入元素,a.insert(len(a), x) 等同于 a.append(x)。
示例
lst = list('Python')
lst.insert(0, 'Java')
print(lst)
['Java', 'P', 'y', 't', 'h', 'o', 'n']
描述
从列表中删除第一个值为 x 的元素。未找到指定元素时,触发 ValueError 异常。
示例
lst = list('Python')
lst.remove('o')
print(lst)
lst.remove('o')
print(lst)
['P', 'y', 't', 'h', 'n']
Traceback (most recent call last):
File "E:\studypy\tmp.py", line 4, in
lst.remove('o')
ValueError: list.remove(x): x not in list
描述
删除列表中指定位置的元素(第i个元素,如果索引越界了则会报错:IndexError),并返回被删除的元素。
未指定位置时,a.pop() 删除并返回列表的最后一个元素。
示例
lst = list('Python')
lst.pop()
print(lst)
lst.pop(0)
print(lst)
lst.pop(10)
print(lst)
['P', 'y', 't', 'h', 'o']
['y', 't', 'h', 'o']
Traceback (most recent call last):
File "E:\studypy\tmp.py", line 6, in
lst.pop(10)
IndexError: pop index out of range
描述
删除列表里的所有元素,相当于 del lst[:]。
注意:del lst[:] 是情况整个列表,使得列表为空。列表还存在,只不过是个空的列表(里面没有元素了)。而 del lst是删除这个列表。列表不存在了,再次引用该列表则会报错。
示例
lst = list('Python')
lst.clear()
print(lst)
[]
参见可迭代对象
章节中序列
小节中的序列count
方法
参见可迭代对象
章节中序列
小节中的序列index
方法
描述
就地排序列表中的元素,要了解自定义排序参数,详见后面的sorted函数。
示例
lst = list('Python132')
lst.sort(reverse=True) # 倒序
print(lst)
lst = list('Python132')
lst.sort(reverse=False) # 顺序
print(lst)
['y', 't', 'o', 'n', 'h', 'P', '3', '2', '1']
['1', '2', '3', 'P', 'h', 'n', 'o', 't', 'y']
描述
就地翻转列表中的元素。
示例
lst = list('Python132')
lst.reverse()
print(lst)
['2', '3', '1', 'n', 'o', 'h', 't', 'y', 'P']
描述
返回列表的拷贝。相当于 lst[:] 。
示例
lst = list('Python')
lst2 = lst.copy()
print(lst2)
['P', 'y', 't', 'h', 'o', 'n']
使用列表方法实现堆栈非常容易,最后插入的最先取出(“后进先出”)。把元素添加到堆栈的顶端,使用 append() 。从堆栈顶部取出元素,使用 pop() ,不用指定索引。例如:
stack = [3, 4, 5]
stack.append(6)
stack.append(7)
print(stack)
stack.pop()
print(stack)
stack.pop()
stack.pop()
print(stack)
[3, 4, 5, 6, 7]
[3, 4, 5, 6]
[3, 4]
列表也可以用作队列,最先加入的元素,最先取出(“先进先出”);然而,列表作为队列的效率很低。因为,在列表末尾添加和删除元素非常快,但在列表开头插入或移除元素却很慢(因为所有其他元素都必须移动一位)。
实现队列最好用 collections.deque,可以快速从两端添加或删除元素。例如:
from collections import deque
queue = deque(["red", "green", "blue"])
queue.append("black")
queue.append("white")
print(queue)
queue.popleft()
print(queue)
queue.pop()
print(queue)
print(list(queue))
deque(['red', 'green', 'blue', 'black', 'white'])
deque(['green', 'blue', 'black', 'white'])
deque(['green', 'blue', 'black'])
['green', 'blue', 'black']