四、 python中的数据类型——列表

列表(list)

列表是一种有序的集合,有点类似c里面的数组。它的特点是,可以随时向里面添加或删除其中的元素,在python中经常用来存放数据。列表的特点是中括号,内部元素用逗号隔开。

1. 在python中使用如下方法定义列表

a = []  #这时候a就是一个空的列表
name = ['Tom']  #这时候name是一个列表,里面有一个字符串,也就是'Tom'
classmates = ['Michael', 'Bob', 'Tracy']  #classmate是一个含有三个字符串的列表
list1 = ['Monday', 1, 2.5]  #list1中有三个元素,字符串、整型、浮点型

在这个列表中,可以放进去任何元素,不论你的元素是字符串、整型、浮点型、还是布尔值、空值,包括列表什么的,都可以放进去。
元素与元素之间,用逗号隔开。

2. 使用索引值获取列表中的值

列表会为每个元素分配序号,这个序号代表它的位置,称为索引(index),第一个元素的位置是0,第二个元素是1,以此类推。

>>> classmates = ['Michael', 'Bob', 'Tracy']  #定义一个列表
>>> print(classmates[0])  #classmates[0]表示classmates中的第一个元素
Michael
>>> b = classmates[1]  #将classmates中的第二个元素赋值给b
>>> print(b)  #打印b的值
Bob

使用索引获取列表中的值时,需要使用中括号来访问,在中括号前面加上列表名,中括号内部是元素的索引。
0代表第一个元素的位置,1代表第二个,-1代表倒数第一个,-2代表倒数第二个

>>> classmates = ['Michael', 'Bob', 'Tracy']  #定义列表
>>> print(classmates[-1])  #打印倒数第一个元素
Tracy
>>> print(classmates[-2])  #打印倒数第二个元素
Bob

使用len()函数,可以查看列表里面有多少个元素

>>> classmates = ['Michael', 'Bob', 'Tracy']
>>> print(len(classmates))
3

3. 添加元素

在python中,列表的操作是非常的灵活的,我们可以向其中添加或删除元素。
添加使用list.append()函数

>>> classmates = ['Michael', 'Bob', 'Tracy']  #定义列表
>>> classmates.append('Tom')  #在classmates结尾加入'Tom'这个字符串元素
>>> print(classmates)  #打印classmates这个列表
['Michael', 'Bob', 'Tracy', 'Tom']

list.append()函数是将元素插入到列表的末尾,当我们想在特定位置插入元素时可以使用list.insert()函数

>>> classmates = ['Michael', 'Bob', 'Tracy']  #定义字典
>>> classmates.insert(1,'Tom')  #在索引位置1插入'Tom'
>>> print(classmates)  #打印列表
['Michael', 'Tom', 'Bob', 'Tracy']

list.insert()函数接受两个参数,第一个参数是插入位置,第二个参数是要插入的元素。

需要注意的是,在使用append和insert时,必须在前面注明要操作的列表。就像上面的例子,我们要操作classmates这个列表,所以必须写成classmates.append()classmates.insert(),如果不这么写,计算机就不知道你要往哪个列表中加入元素。

没有特殊情况的话,推荐使用append()函数添加元素,因为使用append的时候,元素默认加在列表尾部,不会造成其他元素索引值的改变。如果使用insert的话,就像上面的insert(1,'Tom'),在位置1插入'Tom'后,Tom后面所有的元素,索引值都加了一个1,列表中元素越多,受影响的程度越大,因此使用append()函数要比insert()函数更快。

4. 删除元素

删除列表中元素的方法有三种

  1. 使用del删除元素
>>> names = ['Michael', 'Bob', 'Tracy']  #定义列表
>>> del names[1]  #使用del 删除names中的第二个元素
>>> print(names)  #打印列表
['Michael', 'Tracy']

del后面需要用索引的方式表明要删除的元素,也就是上面的例子,names[1]代表names中的第二个元素,使用del即可删除

  1. 使用list.pop()函数删除
>>> names = ['Michael', 'Bob', 'Tracy']  #定义列表
>>> names.pop(1)  #删除names中的第二个元素
'Bob'
>>> print(names)   #打印列表
['Michael', 'Tracy']

list.pop()函数与del差不多,都是使用索引值进行删除,只不过写法不同。
我们可以发现,执行names.pop(1)后,python shell打印出了第二个元素的值,也就是我们要删除的那个值,这是因为pop()这个函数,是有返回值的,有时候我们需要使用这个值,这个时候就可以用变量存起来。

>>> names = ['Michael', 'Bob', 'Tracy']  #定义列表
>>> a = names.pop(1)  #删除names中的第二个元素,并把它赋值给a
>>> print(names)  #打印列表
['Michael', 'Tracy']
>>> print(a)  #打印a
Bob

这样我们就可以通过调用a而使用刚才删掉的元素了。

  1. 使用list.remove()函数删除
>>> names = ['Michael', 'Bob', 'Tracy', 'Bob']  #定义列表
>>> names.remove('Bob')  #删除'Bob'
>>> print(names)  #打印列表
['Michael', 'Tracy', 'Bob']

list.remove()函数的作用是删除第一个匹配的元素,上面的例子中,names这个列表里面,有两个'Bob',remove函数只删除了第一个'Bob'。这就是list.remove()函数的特点。

  1. 使用list.clear()清空列表
    list.clear()可以清空列表,删除内部所有的元素
>>> names = ['Michael', 'Bob', 'Tracy', 'Bob']  #定义列表
>>> names.clear()  #清空列表
>>> print(names)  #打印列表
[]

5. 列表的切片

有时候我们想使用列表的前10个元素,或者前n个元素,这时候就应该使用列表的切片。

>>> names = ['Michael', 'Bob', 'Tracy', 'Tom', 'Jack']  #定义列表
>>> print(names[1:3])  #打印names中的第二个元素到第三个元素
['Bob', 'Tracy']

切片和索引类似,都是使用中括号,区别是,索引中的中括号里面只有一个数,而切片不同。切片是切割列表,形成切割下来的部分形成新的列表。

切片:list[start:end:[step=1]],这就是切片的表达式,要求start和end两者必须有一个,step不是可以不指定,不指定的时候默认为1。

切片该怎么理解呢,start就是开始的位置,end就是结束的位置。切片有个特点是“取前不取后”,看上面那个例子可以发现,1作为start,3作为end,1代表第二个元素,3代表第四个元素,列表切片的时候,是不取后面的那个数字对应的元素的,也就是不取第四个元素,所以names[1:3]只取了第二个元素和第三个元素,这就是所谓的取前不取后。

再看下一个例子。

>>> numbers = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10]  #定义列表
>>> print(numbers[:5])  #打印第一个元素的到第五个元素
[0, 1, 2, 3, 4]
>>> print(numbers[0:5])  #同上
[0, 1, 2, 3, 4]
>>> print(numbers[5:])  #打印第六个元素到最后一个元素
[5, 6, 7, 8, 9, 10]
>>> print(numbers[5:len(numbers)])  #同上
[5, 6, 7, 8, 9, 10]
>>> print(numbers[:])  #不设定start和end
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

当不指定start或者end的时候,start默认为0,end默认为最后一个元素的索引值+1,因为“取前不取后”,要想取到最后一个元素,必须加个1才行。
上例中,用len(numbers)表示了最后一个元素的索引值,因为索引值从0开始,最后一个元素的索引值一定是列表内元素个数-1,根据“取前不取后”,在end位置上的数字应该+1,所以最后就等于len(numbers)了。
当不设定start和end的时候,就默认取所有的元素了。

>>> numbers = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
>>> print(numbers[::2])
[0, 2, 4, 6, 8, 10]
>>> print(numbers[1::2])
[1, 3, 5, 7, 9]

当加入step,这个选项后,step代表步长,默认为1,设定成2的时候,就是隔一个取一个,设定成3时就是隔两个取一个。
上例中,第一个切片,start和end均未设定,因此从第一个元素开始,隔一个取一个,得到了所有奇数位置的元素。
第二个切片,start设定为了1,因此取了所有偶数位置的元素。

6. 其他操作

  1. 组合
    使用'+'号可以将两个列表组合起来。
>>> a = [1, 2, 3]  #定义列表
>>> b = ['a', 'b', 'c']  #定义列表
>>> print(a+b)  #打印列表a和列表b组合成的新列表
[1, 2, 3, 'a', 'b', 'c']
  1. 重复
    使用'*'号进行重复,后面写上重复次数,如下:
>>> a = ['a', 'b']  #定义列表
>>> print(a*3)  #打印列表a重复3次的新列表
['a', 'b', 'a', 'b', 'a', 'b']
  1. 求最大值与最小值
    最大值和最小值分别使用max(list)min(list)
>>> a = [1, 2, 3]  #定义列表
>>> print(max(a))  #打印最大值
3
>>> print(min(a))  #打印最小值
1
  1. 求和
    使用sum(list)进行求和
>>> a = [1, 2, 3]
>>> print(sum(a))
6
  1. 统计某元素出现次数
    使用list.count()函数可以统计某元素在列表中出现的次数。
>>> a = [1, 2, 3, 1, 2, 3, 1, 2, 3]
>>> print(a.count(2))
3
  1. 排序
    使用list.sort()函数可以对原来的列表进行从小到大排序。
>>> a = [5, 3, 2, 5, 7, 1]
>>> a.sort()
>>> print(a)
[1, 2, 3, 5, 5, 7]
  1. 反转
    使用list.reverse()函数可以将列表中的元素反向排练。
>>> a = [1, 2, 3, 5, 5, 7]
>>> a.reverse()
>>> print(a)
[7, 5, 5, 3, 2, 1]
  1. 判断某元素是否在列表内
    使用in可以判断某元素是否在列表内,in是“在……中”的含义
>>> a = [1, 2, 3, 5, 5, 7]
>>> print(3 in a)
True
>>> print(0 in a)
False

3在列表中,0不在列表中,所以3 in a是True,而0 in a是False

  1. 复制
    有些时候,我们想再创建出一个和现有列表一模一样的列表,这时候应该使用list.copy()函数
>>> a = [1, 2, 3, 5, 5, 7]
>>> b = a.copy()
>>> print(b)
[1, 2, 3, 5, 5, 7]

更多关于列表的信息可以通过使用help(list)查看帮助文档。

你可能感兴趣的:(四、 python中的数据类型——列表)