列表(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. 删除元素
删除列表中元素的方法有三种
- 使用
del
删除元素
>>> names = ['Michael', 'Bob', 'Tracy'] #定义列表
>>> del names[1] #使用del 删除names中的第二个元素
>>> print(names) #打印列表
['Michael', 'Tracy']
del后面需要用索引的方式表明要删除的元素,也就是上面的例子,names[1]代表names中的第二个元素,使用del即可删除
- 使用
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而使用刚才删掉的元素了。
- 使用
list.remove()
函数删除
>>> names = ['Michael', 'Bob', 'Tracy', 'Bob'] #定义列表
>>> names.remove('Bob') #删除'Bob'
>>> print(names) #打印列表
['Michael', 'Tracy', 'Bob']
list.remove()
函数的作用是删除第一个匹配的元素,上面的例子中,names这个列表里面,有两个'Bob',remove函数只删除了第一个'Bob'。这就是list.remove()
函数的特点。
- 使用
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. 其他操作
- 组合
使用'+'号可以将两个列表组合起来。
>>> a = [1, 2, 3] #定义列表
>>> b = ['a', 'b', 'c'] #定义列表
>>> print(a+b) #打印列表a和列表b组合成的新列表
[1, 2, 3, 'a', 'b', 'c']
- 重复
使用'*'号进行重复,后面写上重复次数,如下:
>>> a = ['a', 'b'] #定义列表
>>> print(a*3) #打印列表a重复3次的新列表
['a', 'b', 'a', 'b', 'a', 'b']
- 求最大值与最小值
最大值和最小值分别使用max(list)
和min(list)
。
>>> a = [1, 2, 3] #定义列表
>>> print(max(a)) #打印最大值
3
>>> print(min(a)) #打印最小值
1
- 求和
使用sum(list)
进行求和
>>> a = [1, 2, 3]
>>> print(sum(a))
6
- 统计某元素出现次数
使用list.count()
函数可以统计某元素在列表中出现的次数。
>>> a = [1, 2, 3, 1, 2, 3, 1, 2, 3]
>>> print(a.count(2))
3
- 排序
使用list.sort()
函数可以对原来的列表进行从小到大排序。
>>> a = [5, 3, 2, 5, 7, 1]
>>> a.sort()
>>> print(a)
[1, 2, 3, 5, 5, 7]
- 反转
使用list.reverse()
函数可以将列表中的元素反向排练。
>>> a = [1, 2, 3, 5, 5, 7]
>>> a.reverse()
>>> print(a)
[7, 5, 5, 3, 2, 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
- 复制
有些时候,我们想再创建出一个和现有列表一模一样的列表,这时候应该使用list.copy()
函数
>>> a = [1, 2, 3, 5, 5, 7]
>>> b = a.copy()
>>> print(b)
[1, 2, 3, 5, 5, 7]
更多关于列表的信息可以通过使用help(list)
查看帮助文档。