列表的基本特点
- 大小可变,内容可修改
- 是一种顺序结构,可索引可迭代
- 可以由多种元素组合构成(字符串、整数、浮点数、可迭代对象)
列表的初始化
-
[]
:构建一个空的列表 -
list()
: 构建一个空的列表 -
[ele1, ele2, ele3 ... elen]
:构建一个包含如上元素的列表 -
list(iterable)
:使用一个可迭代对象来构建新的列表,列表元素是可迭代对象的元素-
[iterable]
:构建的也时一个列表,但是元素不是iterable中的元素,是iterable的返回类型
-
列表索引、元素修改、长度查询
- 列表的索引
-
list[index]
:使用[]
作为索引符号,index
作为索引标记 -
index
:有正负索引两种形式,正索引从0开始,负索引从-1开始 - 索引越界:会抛出IndexError异常
-
- 元素修改
-
list[index] = value
:修改索引位置处的元素值
-
- 列表长度查询
-
len(list)
:查询list的元素个数,时间复杂度为0(1)
-
列表常用方法
- 列表元素查询(不推荐使用)
-
list.index(value [,start [,end]])
:在列表中查询value第一次出现的位置,可以指定起止索引值 [start, end) - 起止索引默认从左到右
- 匹配不到value值,会抛出ValueError异常
- 时间复杂度:
O(n)
-
- 列表元素计数 ( 不推荐使用)
-
list.count(value)
:查询列表中value出现的总次数 - 时间复杂度:
O(n)
-
- 列表增加元素
-
list.append(object)
:在列表的尾部添加元素 object (最常用)- 返回值为None,表明是在当前的列表中直接修改,不产生新的列表
- 时间复杂度:
O(1)
-
list.insert(index, object)
:在指定索引位置添加元素 object- 返回值为None,就地修改不产生新列表
- 时间复杂度:
O(n)
- 指定索引如果有越界行为,会被强行拉到列表头部和尾部添加元素
-
list.extend(iterable)
:列表扩展,将可迭代对象中的元素依次添加到list中- 返回值为None,对list直接修改不产生新的列表
-
list1 + list2
:表示将两个list连接起来- 产生新的列表,原列表不发生变化
-
list * num
:重复操作- 将列表中的元素重复num次,返回一个新的列表
- 注意非引用对象和引用对象的区别(非引用对象直接复制元素值,引用对象复制内存地址)
-
- 列表删除元素
-
list.remove(value)
:删除从左到右匹配到的第一个值为value的元素- 返回值为None,在原列表上直接修改
- 时间复杂度:
O(n)
-
list.pop([index])
:弹出列表中索引位置index处的元素 (最常用)- 返回值为item ,原列表中有修改
- 如果不指定索引值,默认弹出列表中最后一个元素值(时间复杂度为O(1))
-
list.clear()
:清除列表中的元素- 返回一个空列表
-
列表其他方法
- 列表元素翻转
-
list.reverse()
:将列表元素翻转- 返回None, 就地修改列表
-
- 列表排序
-
list.sort(key=none, reverse=False)
:对列表元素进行排序- 返回None,就地修改列表
- 默认为升序,reverse参数设置为True,将列表翻转排序
-
key=function
:将列表中的元素使用key指定的函数转换成要求的类型
-
列表复制
-
列表浅复制
-
lst1 = lst2
: list1 和 list2 指向同一块内存地址,一个修改两个都变化 -
copy()
:非引用类型变量复制元素值,引用类型变量复制内存地址- 修改非引用类型变量时,彼此不会影响
- 修改引用类型数值会使两个列表中的元素值都修改
- 列表判定:
==
判定两个列表中元素值是否完全一致,会将引用类型中的元素值拿出对比
-
-
列表深复制
-
deepcopy()
:来自copy模块中,会解析引用类型,两个列表之间不在有相互联系
-