共计 1565 个字符,预计需要花费 4 分钟才能阅读完成。
初始化
l1 = [] # 空列表
l2 = [1, "a", 2]
print(l1, l2) # [] [1, 'a', 2]
l3 = list() # list() 括号中放可迭代对象
l4 = list(range(3))
l5 = list("hello")
print(l3, l4, l5) # [] [0, 1, 2] ['h', 'e', 'l', 'l', 'o']
插入
lst = ['a', 'b', 'c']
lst.insert(1, '0') # 在原列表指定索引位置插入值
print(lst) # 结果为:['a', '0', 'b', 'c']
追加
lst = ['a', 'b']
lst.append('c') # 在原列表尾部追加
print(lst) # 结果为:['a', 'b', 'c']
批量追加
lst1 = ['a', 'b']
lst2 = ['c', 'd']
lst2.extend(lst1) # 将列表 1 中的元素添加到列表 2
print(lst2) # 结果为:['c', 'd', 'a', 'b']
删除
lst = ['a', 'b', 'c']
# 在原列表中根据值删除(从左到右找到第一个删除)【慎用,里面没有会报错】lst.remove('a')
print(lst) # 结果为:['b', 'c']
如果被删除的元素有多个,只会删除第一个。
根据索引删除
lst = ['a', 'b', 'c', 'd']
lst.pop() # 删除最后一个
print(lst) # 结果为:['a', 'b', 'c']
lst.pop(1) # 删除索引为 1 的值
print(lst) # 结果为:['a', 'c']
清空原列表
lst = ['a', 'b', 'c', 'd']
lst.clear() # 清空原列表
print(lst) # 结果为:[]
例子
# 边循环边删除列表里的数据
lst = ['a1', 'b1', 'a1', 'd1']
for i in range(len(lst)-1, -1, -1):
item = lst[i]
if item.startswith('a'):
lst.remove(item)
print(lst) # 结果为:['b1', 'd1']
del
把变量完全删除。
获取索引
lst = ['a', 'b', 'c', 'd']
index = lst.index('c') # 根据值获取索引
print(index) # 结果为:2
排序
lst = ['w', 'b', 'c', 'd']
lst.sort() # 从小到大排序
print(lst) # ['b', 'c', 'd', 'w']
lst.sort(reverse=True) # 从大到小排序
print(lst) # ['w', 'd', 'c', 'b']
lst = ['w', 'abc', 'come', 'd']
lst.sort(key=len) # 根据元素长度进行排序
print(lst) # ['w', 'd', 'abc', 'come']
nums = ["1", "234", "10", "3"]
nums.sort(key=int)
print(nums) # ['1', '3', '10', '234']
排序时内部元素无法进行比较时会报错,尽量数据类型统一。
列表反转
lst = ['w', 'b', 'c', 'd']
lst.reverse() # 反转原列表,没啥用的方法。如果想倒过来读取,使用负索引倒着读就行
print(lst) # 结果为:['d', 'c', 'b', 'w']
拷贝
浅拷贝
也叫影子拷贝,遇到引用类型数据,仅仅复制一个引用而已。
>>> a = [1, 2, 3]
>>> b = a
>>> a is b
True
>>> c = a[:]
>>> a is c
False
>>> d = a.copy()
>>> a is d
False
c = a[:] 或者 copy() 创建了 a 列表的浅副本。而 b = a 只复制了列表的引用。
深拷贝
import copy
a = [1, [2, 3], 4]
b = copy.deepcopy(a)
print(a == b) # True
a[1][1] = 100
print(a == b) # False
正文完