列表是有序的可变的元素集合。列表中的每个元素可以使任何数据类型,包括列表本身。
列表生成
Python3中的列表通过定义,for循环,列表推导式等几种方式生成
定义
直接通过中括号`[]`定义一个列表
lis = [1, 2, 'a', [1, 2], (2,), {'key': 222}]
for循环
lis = [] for i in range(10): lis.append(i)
列表推导式
通过列表生成式 [表达式 for 变量 in 列表 [if 条件]] 来实现,其中if条件是可选条件。
>>> lis = [i ** 3 for i in range(10) if i % 2 == 0] >>> print(lis) [0, 8, 64, 216, 512] >>>
列表的切片,索引
列表通过索引的操作和字符串的操作一直,都能进行查询,切片,替换,逆向切片等操作,但是:字符串不能通过索引重新赋值,而list可以。可以通过切片进行重新赋值。
>>> li = ['马拉多纳','外星人','小罗','内马尔'] >>> li[2:3] = ['卡卡','C罗','齐达内','兰帕德'] >>> li ['马拉多纳', '外星人', '卡卡', 'C罗', '齐达内', '兰帕德', '内马尔'] >>> li[2:5:2] = ['皮埃尔','佩佩'] >>> li ['马拉多纳', '外星人', '皮埃尔', 'C罗', '佩佩', '兰帕德', '内马尔'] >>>
列表内置方法
list的内置方法有以下11种,主要是增加,删除,查找,排序,复制,反转的功能:
- append
- insert
- extend
- copy
- count
- remove
- pop
- clear
- sort
- reverse
append
该方法是将某个元素添加到`list`中末尾。
>>> lis = [] >>> lis.append(1) >>> lis.append(2) >>> print(lis) [1, 2] >>>
insert
该方法是将某个元素添加到`list`中指定的索引。
>>> lis.insert(2, 3) >>> print(lis) [1, 2, 3] >>>
extend
该方法是传入一个可迭代对象,然后把每个元素添加到调用该方法的列表中,字符串会拆成一个一个的字符,然后从最后添加进去,只是把第一层添加进去,不会把嵌套的拆开。源码:
def extend(self, iterable): # real signature unknown; restored from __doc__ """ L.extend(iterable) -> None -- extend list by appending elements from the iterable """ pass
实例:
>>> lis = [1, 2, 3] >>> li = [4, 5, 6] >>> lis.extend(li) >>> print(lis) [1, 2, 3, 4, 5, 6] >>> lis.extend('789') >>> print(lis) [1, 2, 3, 4, 5, 6, '7', '8', '9'] >>> print(lis) [1, 2, 3, 4, 5, 6, '7', '8', '9'] >>> li = [10, [11, 12], 13] >>> lis.extend(li) >>> print(lis) [1, 2, 3, 4, 5, 6, '7', '8', '9', 10, [11, 12], 13] >>>
copy
对list进行浅拷贝。返回一个拷贝的列表。
>>> print(lis) [3, 5, 6, '7', [11, 12], 10, 4, '9', 13, '8'] >>> lis2 = lis.copy() >>> print(lis, lis2) ['8', 13, '9', 4, 10, [11, 12], '7', 6, 5, 3] ['8', 13, '9', 4, 10, [11, 12], '7', 6, 5, 3] >>> lis is lis2 False >>>
index
该方法是查找`list`中指定区间内的元素的索引,默认区间是全部列表。如果有,返回第一个找到的索引,反之,抛出ValueError异常。源码:
def index(self, value, start=None, stop=None): # real signature unknown; restored from __doc__ """ L.index(value, [start, [stop]]) -> integer -- return first index of value. Raises ValueError if the value is not present. """ return 0
实例:
>>> lis [1, 2, 3, 3] >>> lis.index(3) 2
count
计算某个元素在list中出现的次数。如果不存在返回0。实例:
>>> print(lis) [1, 2, 3, 4, 5, 6, '7', '8', '9', 10, [11, 12], 13] >>> lis.count('1') 0 >>> lis.count(6) 1 >>>
remove
该方法是删除第一个匹配到的指定的元素,如果不存在,抛出`ValueError`异常。该方法没有返回值。
>>> print(lis) [2, 3, 5, 6, '7', [11, 12], 10, 4, '9', 1, 13, '8', 1] >>> lis.remove(1) >>> print(lis) [2, 3, 5, 6, '7', [11, 12], 10, 4, '9', 13, '8', 1] >>>
pop
该方法是根据指定索引删除元素,默认删除最后一个,***返回被删除的元素。***如果不存在,抛出`ValueError`异常。
>>> print(lis) [2, 3, 5, 6, '7', [11, 12], 10, 4, '9', 13, '8', 1] >>> lis.pop() 1 >>> print(lis) [2, 3, 5, 6, '7', [11, 12], 10, 4, '9', 13, '8'] >>> lis.pop(0) 2 >>> print(lis) [3, 5, 6, '7', [11, 12], 10, 4, '9', 13, '8'] >>>
clear
删除list中的所有元素。返回一个空列表。
>>> print(lis) [[1, 2], [3, 4], [5, 6]] >>> lis.clear() >>> print(lis) [] >>>
sort
对列表进行排序。需注意:
- key -- 主要是用来进行比较的元素,只有一个参数,具体的函数的参数就是取自于可迭代对象中,指定可迭代对象中的一个元素来进行排序。
- reverse -- 排序规则,`reverse = True`降序,`reverse = False`升序(默认)。
>>> print(lis) [4, 10, 13, 6, 5, 3] >>> lis.sort() >>> lis.sort(re) repr( return reversed( >>> lis.sort(reverse=True) >>> print(lis) [13, 10, 6, 5, 4, 3]
带key的排序:
>>> lis = [[1, 2], [3, 4], [5, 6]] >>> shuffle(lis) >>> print(lis) [[1, 2], [5, 6], [3, 4]] >>> lis.sort(key=second_element) >>> print(lis) [[1, 2], [3, 4], [5, 6]] >>>
reverse
该方法将这个列表里的元素反转过来。
>>> print(lis2) ['8', 13, '9', 4, 10, [11, 12], '7', 6, 5, 3] >>> lis2.reverse() >>> print(lis2) [3, 5, 6, '7', [11, 12], 10, 4, '9', 13, '8'] >>>
del关键字删除
删除列表中的元素。删除取到的元素。
>>> lis = [1, 2, 3, 4] >>> del lis[1:2] >>> lis [1, 3, 4] >>> del lis[1] >>> lis [1, 4] >>>
元组
元组是只读列表,值能读,不能修改,但是元组嵌套了其他可变数据类型,可则已修改元组里的可变类型的数据。
>>> tup = (1, 2, [3, 4], 5) >>> tup[2].append(6) >>> tup (1, 2, [3, 4, 6], 5) >>> tup[1] = 0 Traceback (most recent call last): File "<stdin>", line 1, in <module> TypeError: 'tuple' object does not support item assignment >>>
元组由`()`表示,当只有一个元素是,后边要跟`,`括号也可以省虐不写。
>>> t = 1, >>> type(t) <class 'tuple'> >>>
元组的内置方法
元组的内置方法有两个,`count()`和`index()`两个。
count
用于计数。同列表的用法,源码:
def count(self, value): # real signature unknown; restored from __doc__ """ T.count(value) -> integer -- return number of occurrences of value """ return 0
index
用于索引,同list的用法。源码:
def index(self, value, start=None, stop=None): # real signature unknown; restored from __doc__ """ T.index(value, [start, [stop]]) -> integer -- return first index of value. Raises ValueError if the value is not present. """ return 0