列表与元组的主要不同在于,列表是可以修改的,元组不可以。列表适用于需要中途添加元素的情形,元组适用于出于某种考虑禁止修改序列的情形。在需要处理一系列值时,序列很有用,在数据库中,你可能使用序列来表示人,其中第一个表示姓名,第二个表示年龄。用列表表示如下:
user=['Andy',20]
序列还可包含其他序列
user=['Andy',20] use=['john',21] database=[user,usr] database [['Andy', 20], ['john', 21]] data=['Aurora',user] data ['Aurora', ['Andy', 20]]
有几种操作使用于所有序列,包括索引、切片、相加、相乘和成员检查。另外还有一些内置函数,可用于确定序列的长度以及找出序列中最大和最小的元素。
索引:
序列中所有的元素都有编号-从0开始递增
set='Hello' set[0] 'H' 字符串就是由字符组成的序列,索引0指向第一个元素,这里为字母H,不同于其他一些语言,python没有表示字符的类型。因此一个字符就是只包含一个元素的字符串。
这称为索引,还可使用负索引来获取元素
set[-1] 'o'
对于字符串字面量(以及其他序列字面量)可直接对其执行索引操作,无需先将其赋给变量,这与先赋给变量在对变量执行索引操作的效果一样。
'Hello'[1] 'e'
如果函数调用返回一个序列,可直接对其执行索引操作。例如,你只想获取用户输入的姓名第二位:
name=input('name: ')[2] name: john name 'h'
切片:
使用索引来访问单个元素外,还可使用切片来访问特定范围内的元素,使用两个索引用冒号分隔:
tag='python web site' tag[9:30] 'How long have you bee' tag[49:-4] 'python web site'
切片适用于提取序列一部分,其中的编号非常重要,第一个索引是包含第一个元素的编号,第二个索引是切片后前一位的元素编号(下标从0开始)
number=[1,2,3,4,5,6,7,8,9,10] number[3:6] [4, 5, 6]
两个索引来指定切片的边界,其中一个索引指定的元素包含在切片内,第二个索引指定的元素不包含在切片内。
简写:
# 如果切片结束与序列末尾,可省略第二个索引: number[-3:] [8,9,10] # 如果切片始于序列开头,可省略第一个索引: number[:3] [1,2,3] # 复制序列 number[:] [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
步长:
执行切片操作时,显示或隐示地制定起点和终点,但通常省略另一个参数,即步长。在普通切片中,步长为1(从一个元素移动到下一个元素),切片包含起点和终点之间的所有元素。
number[0:10:1] [1, 2, 3, 4, 5, 6, 7, 8, 9, 10] number[0:10:2] [1, 3, 5, 7, 9]
也可以简写:
number[::4] [1, 5, 9]
步长不能为0,但是可以是负数,这样获取元素的位置是从右向左。
number[::-2] [10, 8, 6, 4, 2]
步长为正数时,它从起点移到终点,步长为负数时,它从终点移到起点。
序列相加:
[1,2,3]+[4,5,6] [1, 2, 3, 4, 5, 6] [1,2,3]+'world' Traceback (most recent call last): File "", line 1, in [1,2,3]+'world' TypeError: can only concatenate list (not "str") to list
不能拼接序列与字符串,虽然他们都是序列,一般不能拼接不同类型的序列。
乘法:
'hello' * 2 'hellohello' [2] * 3 [2, 2, 2]
如先定义序列但并不为其赋值可用
name=[None] * 5 name [None, None, None, None, None]
成员资格:
检查特定的值是否包含在序列中,使用in.满足条件返回true,否则返回false.
name='Andy' 'A' in name True # 对于字符串来说只有它包含的字符才是其成员或元素。 'p' in 'python' True
长度、最小值、最大值
number=[100,20,80] len(number) 3 max(number) 100 min(number) 20 max(2,3,7) 7
列表常用方法
#赋值 x = [1,2,1] x[1]= 3 x [1, 3, 1] # 删除元素 x = [1,3,1] del x[1] x [1, 1] # 给切片赋值 name=list('Perl') name ['P', 'e', 'r', 'l'] name[3:]=list('ar') name ['P', 'e', 'r', 'a', 'r'] # 还可以在不删除原有元素的情况下插入新元素 name[1:1]=list('el') name ['P', 'r', 'l', 'e', 'r', 'a', 'r'] del name[1::2] name ['P', 'l', 'r', 'r']
方法是与对象(列表、数、字符串等)联系紧密的函数。
# 在末尾追加元素:append number.append(4) number [1, 2, 3, 4] # 清空列表:clear number.clear() number [] # 复制:copy a = [1,2,3] b = a b[1]=4 b [1, 4, 3] a [1, 4, 3] a = [1,4,3] b=a.copy() b[1]=5 a [1, 4, 3] # 计数:count ['to','be','or','not','to','be'].count('to') 2 x=[[1,2],1,2,[1,2,[2,1]]] x.count(1) 1 # 扩展追加exend a =[1,2,3] b= [4,5,6] a.extend(b) a [1, 2, 3, 4, 5, 6] b [4,5,6] a+b [1, 2, 3, 4, 5, 6, 4, 5, 6] a [1, 2, 3, 4, 5, 6] b [4, 5, 6] # 查找第一次在序列中出现的索引 a =['to','be','or','not','to','be'] a.index('be') 1 a[1] 'be' # inster:插入 number = [1,2,3,4,5] number.insert(2,8) number [1, 2, 8, 3, 4, 5] # pop删除末尾最后一个元素并返回删除元素,pop是唯一既修改列表又返回一个非none值的列表方法。 number.pop() 5 number [1, 2, 8, 3, 4] number.insert(0,number.pop(0)) # 删除第一个指定值的元素 a =['to','be','or','not','to','be'] a.remove('to') a ['be', 'or', 'not', 'to', 'be'] # 倒序排列:reverse number = [2,8,3,4] number.reverse() number [4, 3, 8, 2] # 对列表就地排序指对原表进行修改:sort number = [4,3,8,2] number.sort() number [2, 3, 4, 8]
元组:不可修改的序列
元组的几种写法。
(1,2,3) 1,2,3 (2,) 2,
3 * (20+2) 66 3* (20+2,) (22, 22, 22) (22)与22完全等效,加上逗号,就能完全改变表达式的值
函数tuple的工作原理与list很像,它将一个序列作为参数,并将其转换为元组。如果参数是元组,就原封不动的返回。
tuple([1,2,3]) (1,2,3) tuple('abc') ('a','b','c') tuple((1,2,3)) (1,2,3) x = 1,2,3 x[1] 2 x[0:2] (1,2)