python序列之列表

巴扎黑
Lepaskan: 2017-07-20 09:34:47
asal
1285 orang telah melayarinya

注:本文测试环境为python 2.7

列表(list),同数组不同,它既可以存储相同类型的数据,也可也存储不同类型的数据

list1 = [1,2,3]

list2 = [1,’hello’,False]

列表属于序列,所以兼顾序列的一些通用特性

 

1、索引

list1 = [1,2,3,4]

列表的索引 从左往右,从0开始,依次+1

s1[0]代表第一个元素,这里s1[0] = 1

从右往左取索引,从-1开始,依次-1

s1[-1]代表最后一个元素,这里s1[-1] = 4

 

2、分片

分片操作符为‘:’(冒号),分片操作是生成新列表的一种很便捷的方式

s1 = [1,2,3,4]

s2 = s1[1:3] #第一个参数为开始的索引,第二个参数为结束的索引(结束索引处的元素是无法取到的,1:3只能取到索引1和2)

输出结果:s2 = [2,3]

s3 = s1[1:-1] #这里索引-1相当于上面的3

输出结果:s3 = [2,3]

 

注1:参数1和参数2都可以省略 参数1,省略时代表起始索引0 参数2,省略时代表最大位置索引

注2:s1[-1,1] = [] ,从最后一个索引,取到开始的索引,这样返回是空列表。事实上,当左边的索引比右边晚出现时,都会返回空列表

当我们需要倒取整个列表时,我们引入了步长这个概念

s1[a:b:c],分片操作其实有三个参数,参数1和2已经介绍过了,参数3即为步长,默认步长可以省略,默认为1

所以 s1[:] 返回整个列表 另外 s1[::-1] 返回整个反转列表

 

关于分片操作,我们写如下几行代码

s1 = [1,2,3,4]

s2 = s1 #将s1赋值给s2

s3 = s1[:] #将s1的列表赋值给s3

print s1==s2 #判断s1与s2的值是否相同

print s1==s3

print s1 is s2 #判断s1和s2是否是同一个序列

print s1 is s3

为了拷贝出一个新的序列,直接赋值显然是不行的,我们使用了分片

 

3、加/乘

s1 = [1,2,3]

s2 = [4,5,6]

s = s1+s2 两个列表相加后,返回新列表s=[1,2,3,4,5,6]

s3 = ‘hello’

s4 = (1,2,3)

s1+s3

s1+s4

该语句执行后,会报错

 

注:虽然字符串和元组,都和列表一样为序列,但是两者不能直接相加

这里:引入一个内建函数 list(),可以将字符串或者元组直接转换成字符串 s1 + list(s3) s1 + list(s4) 这样,就可以正常执行了

注:list()可以将字符串、元组等序列转换成列表,如何将列表转换成字符串呢?

eg:s = ’’.join(list1) ,可以将列表list1转换成字符串s

 

列表的乘法 s1 = [1]

s2 = s1*10

返回s2 = [1,1,1,1,1,1,1,1,1,1]

常用于声明空列表

s1 = [None] #这时候使用s1 = [] 是不行的

s2 = s1*10

声明了一个长度为10的空列表

 

4、检查元素是否存在 s1 = [1,2,3]  

if 1 in s1:  

  print "元素存在"

else:

  print "元素不存在"

 

5、列表常用内建函数

list1 = [1,2,3,4]

 

len(list1) #取列表长度

max(list1) #取列表最大值

min(list1) #取列表最小值

sum(list1) #对列表成员求和,求和的列表成员中不能有字符串,否则会报错

cmp(list1,list2) #比较两个列表的大小,返回结果为1,-1,0

比较规则 全是数字,比较最小的数字

字母大于数字

字母从首字母按出现顺序比较

全部一致,比较长度,长的更大 都一致,视为相等,返回0

 


Atas ialah kandungan terperinci python序列之列表. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan