- 列表方法
append()
:在列表末尾添加元素 - 列表方法
insert()
:在列表任意位置插入元素,a.insert(0,1)
,在列表的0号位置插入元素1. - 列表方法
count(s)
:返回s在列表中出现的次数 - 列表方法
remove(s)
:移除列表中的第一个s,从左往右数 - 列表方法
reverse()
:反转整个列表 - 列表方法
extend()
:将一个列表的元素全部添加到另一个列表的末尾,a.extend(b)
,将列表b中所有元素添加到a的末尾 - 列表方法
sort()
:对列表按増序进行排序,前提是列表元素是可排序的。如:`c=[1,’a’,b’],则c不能进行排序。 - 列表方法
pop(i)
:弹出列表的第i个元素,如果没有参数,则默认弹出列表的最后一个元素。 - python关键字
del
:也能对列表进行操作,如del a[0]
表示删除列表的0号元素,del a[-1]
表示删除列表的倒数第一个元素。
将列表用做栈和列表
- 栈:一种LIFO(Last In First Out)数据结构,即后进先出。
- 队列:一种FIFO(First In First Out)数据结构,即先进先出。
实现方法:
1、实现栈
添加元素时,用append()方法,将元素添加到列表的末尾。
删除元素是,用pop()方法,将列表末尾的元素弹出。
2、实现队列
添加元素时,用append()方法,将元素添加到列表的末尾。
删除元素时,用pop(0)方法,将列表首的元素删除。
列表推导式
列表推导式由包含一个表达式的中括号组成,表达式后面跟随一个for字句,之后可以有多个for或者if字句。列表推导式的结果是一个列表。如
>>>[(x,y) for x in [1,2,3] for y in [3,1,4] is x!=y]
[(1,3),(1,4),(2,3),(2,1),(2,4),(3,1),(3,4)]
等同于:
>>>combs=[]
>>>for x in [1,2,3]
... for y in [3,1,4]
... if x!=y:
... combs.append((x,y))
...
列表推导式也可以嵌套:
>>> a=[1,2,3]
>>>z=[x+1 for x in [x**2 for x in a]]
>>>z
[2,5,10]
如果没有列表推导式,一般都是这样创建列表:
通过将一些操作应用于序列的每个成员并通过返回的元素创建列表,或者通过满足特定条件的元素创建子序列。
假设要创建一个squares列表,方法1:
>>>squares=[]
>>>for x in range(10):
... squares.append(x**2)
...
>>>squares
[0,1,4,9,16,25,36,49,64,81]
但是这个方法有个副作用,就是x变量在循环完毕后依然存在。
>>>x
>>>9
方法2
squares=list(map(lambda x:x**2,range(10)))
方法3
squares=[x**2 for x in range(10)]
方法2和方法3都没有副作用