05.列表

接下来一起来学习下列表

什么是列表?

列表就是一个有序的数据集合,在里面可以随意的添加和删除其中的元素,元素可以为任意类型

创建列表

data1 = ['1',1] # 通过[]将数据放在一起

data2 = ['1',2,[1,2,3],4] # 列表中元素也可以为一个序列

empty = []

通过下标取得列表中的单个值

注意,列表中的元素的位置,是从0开始计数的

>>> a = [1,2,3,4]
>>> a
[1, 2, 3, 4]
>>> a[0]
1
>>> a[1]
2
>>> a[2]
3
>>> a[3]
4

注意,如果下标的大小超过了列表中的元素个数,会报错

>>> a[4]
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
IndexError: list index out of range

负数下标

在python中,支持负数下标。

>>> a = [1,2,3,4]
>>> a
[1, 2, 3, 4]
>>> a[-1]
4
>>> a[-2]
3
>>> a[len(a)-1]
4
>>> a[len(a)-2]
3

负数下标中整数值-1指的是列表中的最后一个下标,-2指的是列表中倒数第二个下标,以此类推。另外a[-i] 等价于a[len(a)-1]

如何使用切片

如果想从列表提取多个值,该怎么办?使用下标的话,太麻烦了,这时可以使用切片,切片可以从列表中取得多个值,得到的结果是一个新的列表

格式

list[start,stop,step]

参数

  • start:表示切片开始的下标位置

  • stop:表示切片结束处的下标位置,不包括stop这个位置

  • step:步长

实例

>>> a = [1,2,3,4,5,6,7,8,9]
>>> a
[1, 2, 3, 4, 5, 6, 7, 8, 9]

>>> a[1:]
[2, 3, 4, 5, 6, 7, 8, 9]
>>> a[1:len(a)]
[2, 3, 4, 5, 6, 7, 8, 9]

>>> a[:5]
[1, 2, 3, 4, 5]
>>> a[0:5]
[1, 2, 3, 4, 5]

>>> a[0:5:2]
[1, 3, 5]

>>> a[::2]
[1, 3, 5, 7, 9]
>>> a[0:len(a):2]
[1, 3, 5, 7, 9]

用del语句从列表中删除值

del语句将删除列表中下标处的值,列表中被删除值后面的所有值,都将向前移动一个下标

>>> a = [1,2,3,4,5,6,7,8,9]

>>> a[1:5]
[2, 3, 4, 5]
>>> del a[1:5]
>>> a
[1, 6, 7, 8, 9]

>>> a[0]
1
>>> del a[0]
>>> a
[6, 7, 8, 9]

向列表添加元素

  • list.append(x)

    • 将项添加到列表的末尾。相当于。a[len(a):] = [x]

>>> a = [1,2,3,4,'angle']
>>> a
[1, 2, 3, 4, 'angle']
>>> a.append(2)
>>> a
[1, 2, 3, 4, 'angle', 2]
>>> a.append("name")
>>> a
[1, 2, 3, 4, 'angle', 2, 'name']
>>> a[len(a):] = ["123"]
>>> a
[1, 2, 3, 4, 'angle', 2, 'name', '123']
  • list.extend(iterable)

    • 通过附加iterable中的所有项来扩展列表。相当于 。a[len(a):] = iterable

>>> a = [1,2,3]
>>> a
[1, 2, 3]
>>> b = [4,5,6]
>>> a.extend(b)  # 将一个列表的元素追加到另一列表的末尾中
>>> a
[1, 2, 3, 4, 5, 6]
  • list.insert(i,x)

    • 在给定位置插入项目,第一个参数是要插入的元素的索引,第二个参数是即将要插入的元素

>>> a = [1,3,5,7]
>>> a
[1, 3, 5, 7]
>>> a.insert(1,2) # 插入到第一个位置,也就是原来的3位置,插入后,3以及3以后的元素,都往后退一位
>>> a
[1, 2, 3, 5, 7]
>>> a.insert(3,4)
>>> a
[1, 2, 3, 4, 5, 7]

删除列表中的元素

  • list.remove(x )

    • 从列表中删除值等于x的第一个项目。ValueError如果没有这样的项目,它会引发一个

>>> a = [1,2,3,4,5,6]
>>> a
[1, 2, 3, 4, 5, 6]
>>> a.remove(1)  # 删除指定值相同的元素
>>> a
[2, 3, 4, 5, 6]
>>> a.remove(5)
>>> a
[2, 3, 4, 6]
  • list.pop([ i ] )

    • 删除列表中给定位置的项目,然后将其返回。如果未指定索引,则a.pop()删除并返回列表中的最后一项。(方法签名中i周围的方括号表示该参数是可选的,而不是您应该在该位置键入方括号。您将在Python Library Reference中经常看到这种表示法)

>>> a
[1, 2, 3, 4, 5, 6]
>>> a.pop() # 默认删除最好一个元素,相当于a.pop(len(a)-1)
6
>>> a.pop(4) # 删除指定位置在第4个的元素
5
>>> a.pop(1)
2
>>> a
[1, 3, 4]
>>> a.pop(0)
1
>>> a
[3, 4]
  • list.clear()

    • 从列表中删除所有项目,相当于del a[:]

>>> a = [1,2,3,4,5,6]
>>> a
[1, 2, 3, 4, 5, 6]
>>> a.clear()  # 清除列表中的元素,但不会删除列表对象
>>> a
[]


>>> a = [1,2,3,4,5,6]
>>> del a  # 删除列表对象
>>> a
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
NameError: name 'a' is not defined

查找列表中的值

  • list.index(x [,start [,end ] ] )

    • 在值等于x的第一个项的列表中返回从零开始的索引。ValueError如果没有这样的项目,则提高a 。

    • 可选参数start和end被解释为切片表示法,并用于将搜索限制为列表的特定子序列。返回的索引是相对于完整序列的开头而不是start参数计算的。

>>> a = [3,5,6,4,1,9]
>>> a
[3, 5, 6, 4, 1, 9]
>>> a.index(5)
1
>>> a.index(1)
4
>>> a.index(1,4)
4
>>> a.index(1,5)  # 为什么报错,因为索引是从第5个位置开始索引的
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
ValueError: 1 is not in list
>>> a.index(1,2,5)
4
>>> a.index(3,2,5)
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
ValueError: 3 is not in list

更新列表的值

可以对列表的数据项进行修改或更新

>>> a = [1,2,3,4]
>>> a[0] = 'angle'
>>> a
['angle', 2, 3, 4]

为列表进行排序

  • list.sort(key = None,reverse = False )

    • 对列表中的项目进行排序(参数可用于排序自定义,请参阅sorted()其说明)

>>> a = [9,6,3,4,7,]
>>> a
[9, 6, 3, 4, 7]

>>> a.sort()
>>> a
[3, 4, 6, 7, 9]

# 利用key进行倒序排序
>>> a = [9,6,3,4,7,]
>>> a.sort(key=lambda x:-x)
>>> a
[9, 7, 6, 4, 3]

# 反向排序
>>> a = [9,6,3,4,7,]
>>> a.sort(reverse=True)
>>> a
[9, 7, 6, 4, 3]
  • list.reverse()

    • 反转列表中的元素

>>> a
[9, 7, 6, 4, 3]
>>> a = [9,6,3,4,7,]

>>> a.reverse() # 这是反转列表,注意没有进行排序
>>> a
[7, 4, 3, 6, 9]

复制列表

  • list.copy()

    • 返回列表的浅表副本。相当于a[:]

浅复制仅仅复制了容器中元素的地址

>>> a = [1,2,[3,4]]
>>> b = a.copy()    # 浅拷贝:深拷贝父对象(一级目录),子对象(二级目录)不拷贝,还是引用
>>> c = a           # 浅拷贝: 引用对象
>>> b
[1, 2, [3, 4]]
>>> a
[1, 2, [3, 4]]
>>> a[2]
[3, 4]

# 注意
>>> a[2].append(2)
>>> b
[1, 2, [3, 4, 2]]
>>> a.append(1)

# b[2]有新元素添加了,其余没变动
>>> b
[1, 2, [3, 4, 2]]
>>> a
[1, 2, [3, 4, 2], 1]
>>> c
[1, 2, [3, 4, 2], 1]

有时候一个一个输出相同的列表,很麻烦,这时候可以这样输出

>>> a = [1,2,3,4]
>>> a * 3 #这样就可以快速输出三个相同的列表,并且自动连接在一起
[1, 2, 3, 4, 1, 2, 3, 4, 1, 2, 3, 4]

列表之间的连接

列表之间的连接通过‘+’连接在一起

>>> a = [1,2,3,4]
>>> b = [5,6,7]
>>> a+b
[1, 2, 3, 4, 5, 6, 7]

列表用于循环

>>> for i in range(4):
...     print(i)
...
0
1
2
3

range(4)的返回值是类似于列表的值,python认为类似于[0,1,2,3]

>>> for i in [0,1,2,3]:
...     print(i)
...
0
1
2
3

前面的for循环实际上是在循环执行它的子句,在每次迭代中,让变量依次设置列表中的值

常见的python技巧,是在for循环中使用range(len(someList)),迭代列表中的每一个下标

>>> word = ["a","b","c","d"]
>>> word
['a', 'b', 'c', 'd']
>>> for i in range(len(word)):
...     print(word[i])
...
a
b
c
d

使用列表作为堆栈(先进后出)

list方法可以很容易地将列表用作堆栈,其中添加的最后一个元素是检索到的第一个元素(“last-in,first-out”)。要将项添加到堆栈顶部,请使用append()。要从堆栈顶部检索项目,请在pop()没有显式索引的情况下使用

>>> stack = [1,2,3,]
>>> stack
[1, 2, 3]
>>> stack.append(4)
>>> stack
[1, 2, 3, 4]
>>> stack.pop()
4
>>> stack
[1, 2, 3]

使用列表作为队列(先进先出)

要实现队列,请使用collections.deque设计为具有快速追加和从两端弹出的队列

描述

返回一个从左到右(使用append())初始化的新deque对象,其中包含来自iterable的数据。如果未指定iterable,则新的deque为空。

Deques是堆栈和队列的概括(名称发音为“deck”,是“双端队列”的缩写)。Deques支持线程安全,内存有效的附加和从双端队列的弹出,在任一方向上具有大致相同的O(1)性能。

虽然list对象支持类似的操作,但它们针对快速固定长度操作进行了优化,并且导致O(n)内存移动成本 pop(0)和操作,这些操作改变了底层数据表示的大小和位置。insert(0, v)

如果未指定maxlenNone,则deques可能会增长到任意长度。否则,双端队列限制为指定的最大长度。一旦有界长度双端队列已满,当添加新项目时,从对方端丢弃相应数量的项目。有界长度deques提供类似于tailUnix中的过滤器的功能。它们还可用于跟踪仅涉及最近活动的事务和其他数据池。

语法

collections.deque([ iterable [,maxlen ] ] )

支持方法

  • append(x )

    • 将x添加到双端队列的右侧。

  • appendleft(x )

    • 将x添加到双端队列的左侧。

  • clear()

    • 从双端队列中删除所有元素,使其长度为0。

  • copy()

    • 创建deque的浅表副本。

  • count(x )

    • 计算deque元素的数量等于x。

  • extend(可迭代的)

    • 通过附加可迭代参数中的元素来扩展双端队列的右侧。

  • extendleft(可迭代的)

    • 通过附加来自iterable的元素来扩展双端队列的左侧。注意,左边的序列会导致反转迭代参数中元素的顺序。

  • index(x [,start [,stop ] ] )

    • 返回deque中的x位置(在索引开始时或 索引停止之前)。返回第一个匹配或ValueError如果未找到则引发 。

  • insert(i,x )

    • 将x插入位置i的双端队列中。

    • 如果插入会导致有界双端超过maxlen,IndexError则会引发a。

  • pop()

    • 从双端队列的右侧移除并返回一个元素。如果没有元素,则提出一个IndexError。

  • popleft()

    • 从双端队列的左侧移除并返回一个元素。如果没有元素,则提出一个IndexError。

  • remove(值)

    • 删除第一次出现的值。如果没有找到,提出一个 ValueError。

  • reverse()

    • 在原地反转deque的元素然后返回None。

  • rotate(n = 1 )

    • 向右旋转deque n步。如果n为负数,则向左旋转。

    • 当双端队列不为空时,向右d.appendleft(d.pop())旋转一步相当于,向左旋转一步相当于d.append(d.popleft())。

  • maxlen*(只读属性)*

    • 一个双端队列的最大大小或None无边界。

>>> from collections import deque
>>> d = deque('ghi')                 # make a new deque with three items
>>> for elem in d:                   # iterate over the deque's elements
...     print(elem.upper())
G
H
I

>>> d.append('j')                    # add a new entry to the right side
>>> d.appendleft('f')                # add a new entry to the left side
>>> d                                # show the representation of the deque
deque(['f', 'g', 'h', 'i', 'j'])

>>> d.pop()                          # return and remove the rightmost item
'j'
>>> d.popleft()                      # return and remove the leftmost item
'f'
>>> list(d)                          # list the contents of the deque
['g', 'h', 'i']
>>> d[0]                             # peek at leftmost item
'g'
>>> d[-1]                            # peek at rightmost item
'i'

>>> list(reversed(d))                # list the contents of a deque in reverse
['i', 'h', 'g']
>>> 'h' in d                         # search the deque
True
>>> d.extend('jkl')                  # add multiple elements at once
>>> d
deque(['g', 'h', 'i', 'j', 'k', 'l'])
>>> d.rotate(1)                      # right rotation
>>> d
deque(['l', 'g', 'h', 'i', 'j', 'k'])
>>> d.rotate(-1)                     # left rotation
>>> d
deque(['g', 'h', 'i', 'j', 'k', 'l'])

>>> deque(reversed(d))               # make a new deque in reverse order
deque(['l', 'k', 'j', 'i', 'h', 'g'])
>>> d.clear()                        # empty the deque
>>> d.pop()                          # cannot pop from an empty deque
Traceback (most recent call last):
    File "<pyshell#6>", line 1, in -toplevel-
        d.pop()
IndexError: pop from an empty deque

>>> d.extendleft('abc')              # extendleft() reverses the input order
>>> d
deque(['c', 'b', 'a'])

列表推导式

列表推导式(又称列表解析式)提供了一种简明扼要的方法来创建列表

举个栗子

a = []
for i in range(1,10):
    a.append(i)
print(a)

运行结果:

[1, 2, 3, 4, 5, 6, 7, 8, 9]

是不是看起来代码太多了,这时可以使用列表推倒式

b = [i for i in range(1,10)]
print(b)

运行结果:

[1, 2, 3, 4, 5, 6, 7, 8, 9]

这样写起来是不是方便很多了

最后更新于

这有帮助吗?