本篇将介绍python中的列表,更多内容请参考:Python学习指南
一、序列
在python中有六种内建的序列:列表、元祖、字符串、Unicode字符串、buffer对象he xrange对象。
通用序列操作
所有的序列都可以进行某些特定的操作。这些操作包括:
- 索引(indexing)
- 分片(sliceing)
- 加(adding)
- 乘(multiplying)
- 检查某个元素是否属于这序列的(index)
- 计算序列长度(len)
- 找出最大元素和最小元素(min/max)
二、列表的增、删、改操作
Python内置的一种数据类型是列表:list是一种有序的集合,可以随时添加和删除其中的元素。比如,列出班里所有同学的名字,就可以用一个list表示:
>>>classmates = ['Michael', 'Bob', 'Tracy']
>>>classmates
list里面的元素的数据类型也可以不同,比如:
>>>L=['Apple', 123, True]
list元素也可以是另一个list,比如:
>>>s = ['python', 'Java', ['asp', 'php'], 'scheme']
>>>len(s)
要注意s
只有4个元素,其中s[2]
又是一个list,如果拆开写就更容易理解:
>>>p = ['asp', 'php']
s = ['python', 'java', p, 'scheme']
要拿到'php'可以写p[1]
或者's[2][1]',因此s
可以看成是一个二维数组,类似的还有三维、四维...数组,不过很少用到。
如果一个list中一个元素也没有,就是一个空的list,它的长度为0:
>>>L = []
>>>len(L)
0
列表的长度
变量classmates
就是一个list。用len()
函数可以获得list元素的个数:
>>>len(clasmates)
3
列表的赋值
要把某个元素替换成别的元素,可以直接赋值给对应的索引位置:
>>>classmats[1] = 'Sarah'
>>>classmates
['Michael', 'Sarah', 'Tracy']
列表的取值
用索引来访问list中每一个位置的元素,记得索引是从0
开始的:
>>>classmates[0]
'Michael'
>>>classmates[1]
'Bob'
>>>classmates[2]
'Tracy'
>>>classmates[3]
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
IndexError: list index out of range
当索引超出了范围时,Python会报一个IndexError错误,索引,要确保索引不要越界,记得最后元素的索引是len(classmates)-1
如果要取最后一个元素,除了计算索引位置外,还可以用-1
做索引,直接获取最后一个元素:
classmates[-1]
'Tracy'
以此类推,可以获取倒数第2个、倒数第3个:
>>>classmates[-2]
'Bob'
>>>classmates[-3]
'Michael'
>>>classmates[-4]
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
IndexError: list index out of range
当然,倒数第4个旧越界了。
列表的增加操作
append()方法
:list是一个可变的有序表,所以,可以往list中追加元素到末尾:
>>>classmates.append('Adam')
>>>classmates
['Michael', 'Bob', 'Tracy', 'Adam']
注意:append()方法是把添加的参数作为列表的一个元素添加进去的,即使添加列表,也把这个列表当做一个元素
>>>list1 = ['a', 'b', 'c']
>>>list1.append(['1', '2'])
>>>list1
['a', 'b', 'c', ['1', '2']]
extend()方法
:使用extend()方法在列表尾部拼接另一个列表
>>>list = [11, 22, 33, 44, 55, 66]
>>> list.extend([55, 44, 33, 22, 11])
>>> print(list)
[11, 22, 33, 44, 55, 66, 55, 44, 33, 22, 11]
insert()方法
:也可以把元素插入到指定的位置,比如索引号为1
的位置:
>>>classmates.insert(1, 'Jack')
classmates
['Michael', 'Jack', 'Bob', 'Tracy', 'Adam']
+操作
:使用+运算符来实现列表的拼接。类似于extend()方法
>>>list1 = [123]
>>>list2 = [234, 345]
>>>list4 = list1 + list2
[123, 234, 345]
list4 = list1+list2 这种形式是通过两个列表重新创建了一个新的列表,而list1 += list2这种形式是在原有列表的基础上进行拼接操作。
列表的删除操作
pop()方法
:要删除list末尾的元素,用pop()
方法:
>>>classmates.pop()
'Adam'
>>>classmates
['Michael', 'Jack', 'Bob', 'Tracy']
要删除指定位置的元素,用pop(i)
方法,其中i
是索引位置:
>>>classmates.pop(1)
'Jack'
>>>classmates
['Michael', 'Bob', 'Tracy']
remove()方法
:删除指定内容,可以根据列表的值来进行删除
>>>nameinfo = ['name1', 'name2', 'name3']
>>>nameinfo.remove('name1')
>>>nameinfo
['name2', 'name2']
'del()方法':可以使用del语句删除列表的元素,
>>>nameinfo = ['name1', 'name2', 'name3']
>>> del nameinfo[1:3] #删除第1-2字段,不会匹配当前3字段
>>> nameinfo
['name1']
'clear()方法':清除列表中的所有元素,保留列表这个对象
>>> list.clear()
>>> print(list)
[]
三、列表的查询操作
index()方法
:根据提供的value值返回对应的索引下标
>>>nameinfo = ['name1', 'name2', 'name3']
>>>nameinfo.index('name2')
1
[]操作
:根据位置取字符串
>>>nameinfo = ['name1', 'name2', 'name3']
>>>nameinfo[2]
'name3'
'[]分片操纵':返回列表的某一段
>>>nameinfo = ['name1', 'name2', 'name3', 'name4', 'name5']
>>>nameinfo[1:2]
'name2'
>>>nameinfo[1:4]
['name2', 'name3', 'name4']
'count()方法':计算value值在列表中出现的次数
>>>nameinfo = ['name1', 'name2', 'name3', 'name4', 'name5', 'nam44']
>>>nameinfo.count('name4')
2
'max()/min()方法':查询列表中的最大值/最下值
>>>a = [45, 9, 5, 4, 3, 2, 2, 2, 1, 1]
>>>max(a)
45
>>>min(a)
1
sort()/reverse()方法
:列表的排序与倒序
>>> a=[5,2,2,34,5,2,235,25,6,235,5,6,6]
>>> a
[5, 2, 2, 34, 5, 2, 235, 25, 6, 235, 5, 6, 6]
>>> a.sort()
>>> a
[2, 2, 2, 5, 5, 5, 6, 6, 6, 25, 34, 235, 235]
>>> a.reverse()
>>> a
[235, 235, 34, 25, 6, 6, 6, 5, 5, 5, 2, 2, 2]
python列表生成式
>>>[i for i in range(10) if i %2 == 0]
[0, 2, 4, 6, 8]
内建函数enumerate()
作用:在列表中为获得序号提供了一个更方便的方法
>>>seq = ['a', 'b', 'c']
>>>for i, element in enumerate(seq):
seq[i] = "%d:%s"%(i, element)
总结:每当需要对列表进行循环操作时,应该考虑列表解析