1、函数list
list()可以将任何序列转换为列表
>>> list('hello')
['h', 'e', 'l', 'l', 'o']
2、列表的基本操作
列表可以执行所有标准序列操作,如索引、切片、拼接和相乘。
2.1、通过索引给特定位置的元素赋值
>>> x = [1, 1, 1]
>>> x[1] = 2
>>> x
[1, 2, 1]
2.2、删除元素
>>> names = ['tom', 'john', 'alice']
>>> del names[1]
>>> names
['tom', 'alice']
2.3、给切片赋值
>>> name = list('Perl')
>>> name
['P', 'e', 'r', 'l']
>>> name[2:] = list('ar')
>>> name
['P', 'e', 'a', 'r']
使用切片赋值可以在不替换原有元素的情况下插入新元素(替换一个空切片)
>>> numbers = [1, 5]
>>> numbers[1:1] = [2, 3, 4]
>>> numbers
[1, 2, 3, 4, 5]
也可以使用相反的操作来删除切片
>>> numbers
[1, 2, 3, 4, 5]
>>> numbers[1:4] = []
>>> numbers
[1, 5]
3、列表方法
3.1、append:将一个对象附加到列表末尾
>>> lst = [1, 2, 3]
>>> lst.append(4)
>>> lst
[1, 2, 3, 4]
3.2、clear:清空列表的内容
>>> lst = [1, 2, 3, 4]
>>> lst.clear()
>>> lst
[]
3.3、copy:复制列表
>>> a = [1, 2, 3]
>>> b = a.copy()
>>> b[1] = 4
>>> b
[1, 4, 3]
>>> a
[1, 2, 3]
3.4、count:计算指定元素在列表中出现的次数
>>> lst = [1, 2, 3, 4, 1]
>>> lst.count(1)
2
>>> lst.count(2)
1
3.5、extend:使用一个列表来扩展另一个列表
>>> a = [1, 2, 3]
>>> b = [4, 5, 6]
>>> a.extend(b)
>>> a
[1, 2, 3, 4, 5, 6]
3.6、index:查找指定元素在列表中第一次出现的索引
>>> lst = ['to', 'be', 'or', 'not', 'to', 'be']
>>> lst.index('be')
1
3.7、insert:将一个元素插入列表
>>> numbers = [1, 2, 3, 5, 6, 7]
>>> numbers.insert(3, 'four')
>>> numbers
[1, 2, 3, 'four', 5, 6, 7]
3.8、pop:从列表中删除一个元素,并返回这个元素,默认删除最后一个
>>> x = [1, 2, 3, 4, 5, 6]
>>> x.pop()
6
>>> x.pop(2)
3
3.9、remove:删除列表中第一个指定的元素
>>> lst = ['to', 'be', 'or', 'not', 'to', 'be']
>>> lst.remove('be')
>>> lst
['to', 'or', 'not', 'to', 'be']
3.10、reverse:按相反的顺序排列列表中的元素
>>> x = [1, 2, 3]
>>> x.reverse()
>>> x
[3, 2, 1]
*如果要按相反的顺序迭代序列,可以使用函数reversed。这个函数不返回列表,而是返回一个迭代器。可以使用list()将返回的迭代器对象转换为列表。
>>> x = [1, 2, 4, 5, 6, 9]
>>> list(reversed(x))
[9, 6, 5, 4, 2, 1]
3.11、sort:对列表排序
>>> x = [5, 6, 4, 2, 1, 9]
>>> x.sort()
>>> x
[1, 2, 4, 5, 6, 9]
sort方法接受两个可选参数:key、reverse。
>>> x = ['abc', 'python', 'a']
>>> x.sort(key=len) # 按长度排序
>>> x
['a', 'abc', 'python']
>>> x = [4, 6, 2, 1, 7, 9]
>>> x.sort(reverse=True) # 倒序排列
>>> x
[9, 7, 6, 4, 2, 1]
*同样的,可以使用sorted函数对序列进行排序。
>>> sorted('Python')
['P', 'h', 'n', 'o', 't', 'y']