python列表总结

  • 列表方法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都没有副作用

猜你喜欢

转载自blog.csdn.net/Betterc5/article/details/82026705