手机版
你好,游客 登录 注册 搜索
背景:
阅读新闻

关于 Python的序列心得笔记

列表 1

[日期:2017-07-29] 来源:Linux社区  作者:gametesting [字体: ]

注:本文测试环境为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

 

列表的通用方法见第二篇

更多详情见请继续阅读下一页的精彩内容http://www.linuxidc.com/Linux/2017-07/145966p2.htm

linux
【内容导航】
第1页:列表 1 第2页:列表 2
第3页:元组
相关资讯       Python序列 
本文评论   查看全部评论 (0)
表情: 表情 姓名: 字数

       

评论声明
  • 尊重网上道德,遵守中华人民共和国的各项有关法律法规
  • 承担一切因您的行为而直接或间接导致的民事或刑事法律责任
  • 本站管理人员有权保留或删除其管辖留言中的任意内容
  • 本站有权在网站内转载或引用您的评论
  • 参与本评论即表明您已经阅读并接受上述条款