本篇将介绍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
可以看成是一个二维数组,类似的还有三维、四维...数组,不过很少用到。
>>>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 "", line 1, in 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 "", line 1, in 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)
总结:每当需要对列表进行循环操作时,应该考虑列表解析