文档章节

列表和元组——Python学习系列之二

 无聊书生
发布于 2015/09/05 22:36
字数 2507
阅读 48
收藏 0

列表和元组

数据结构:是通过某种方式组织在一起的数据元素的集合,这些元素可以是数字或者是字符,甚至可以是其他数据结构。

序列

序列中每一个元素被分配一个序号——即元素的位置,也称索引。

python有6种内建序列:字符串(一个由字符组成的序列)、元组、列表、Unicode字符串、buffer对象、xrange对象。

通用序列操作

索引

    序列中的所有元素都是有编号的——从0开始递增。

>>> seq_str = 'Hello world!'
>>> seq_str[0]
'H'

分片

    分片操作用来访问一定范围内的元素。分片通过冒号隔开的两个索引来实现

>>> slice_str = [1,2,3,4,5,6,7,8,9,10] 
>>> slice_str[0:3]
[1, 2, 3]
>>> slice_str[-3:-1] #负数表示从序列的后往前数
[8, 9]
>>> slice_str[-3:]#冒号右边值为空,则表到序列的终点
[8, 9, 10]
>>> slice_str[:3]#冒号左边值为空,则表从序列的起点开始
[1, 2, 3]
>>> slice_str[:]#冒号两边值为空,则表示序号全部
[1, 2, 3, 4, 5, 6, 7, 8, 9, 10] 
>>> slice_str[0:9:2] #步长 为正数时python会从序列的头部开始向右提取元素,直到最后一个元素
[1, 3, 5, 7, 9]
>>> slice_str[8:3:-1]#步长 为正数时python会从序列的尾部开始向左提取元素,直到第一个元素
[9, 8, 7, 6, 5]

 

序列相加

通过使用+运算符可以进行序列的链接操作

>>> [1,2,3] + [4,5,6,7]
[1, 2, 3, 4, 5, 6, 7]

乘法

用数字x乘以一个序列会生成新的序列,而在新的序列中,原来的序列将被重复x次

>>> [42] * 5
[42, 42, 42, 42, 42] 
>>> seq_none = [None] * 10 #设置占用10空的元素空间,却不包含任何有用内容的列表
>>> seq_none
[None, None, None, None, None, None, None, None, None, None]

成员资格

    成员资格表示:检查一个值是否在序列中,可以in运算符。in运算符检查条件是否为真。为真返回True,为假范围Flase

>>> person = ['zhangsan','lisi','wanger']
>>> 'lisi' in person
True

长度、最大值、最小值

>>> numbers = [10,23,97,9]
>>> len(numbers)
4
>>> max(numbers)
97
>>> min(numbers)
9

序列表示方式

字符串:user_name = 'zhangsan'

元组:不可变的序列,

>>> xx = 1,2,3
>>> xx
(1, 2, 3)

列表:person = ['zhangsan','lisi','wanger']

字典:字典中的值并没有特殊的顺序,但都是存储在一个特定的键下。键可以是数字、字符串甚至是元组

people = {
            'aiyungui':{
                        'address':"湖南省长沙市",
                        'phone':"18618181818"
                       },
            'aizhonglan':{
                            'address':"北京市海淀区",
                            'phone':"18618180107"
                          }
          }

注:元组使用的两个不可替代的原因

    1、元组可以在影射(和集合成员)中当键使用,而列表则不行。

    2、元组作为很多内建函数和方法的返回值存在,也就是说你必须对元组进行处理。

列表的方法

方法 描述
alist.append(obj) 等同于alist[len[alist]:len[alist]] = [obj]
alist.count(obj) 返回alist[i]==obj中的索引i的数值
alist.extends(sequence) 等同于alist[len[alist]:len[alist]] = [obj]=sequence
alist.index(obj) 返回alist[i]==obj中最小的i(如果i不存在会引发valueError异常)
alist.insert(index,obj) 如果index>0,等同于alist[index:index]=[obj];如果index<0,将obj置于列表的最前面
alist.pop([index]) 移除并返回给定索引的项,默认为-1
alist.remove(obj) 移除列表中匹配值obj的第一个选项。
alist.reverse() 原地反转alist选项
alist.sort([cmp],[,key][,reverse]) 对alist中的项进行原地排序。可以提供比较函数cmp,创建用于排序的键的key函数和reveser标志进行自定义

注:下述字典方法、字符串方法从网上其他博客中复制。

字典的方法

方法

说明

clear( )

从字典删除所有项

copy( )、deepcopy(obj)

创建并返回字典的浅拷贝(新字典元素为原始字典的引用)

get(key [ ,returnvalue] )

返回key的值,若无key而指定了returnvalue,则返回returnvalue 值,若无此值则返回None

has_key( key )

如果key存在于字典中,就返回1(真);否则返回0(假)

items( )

返回一个由元组构成的列表,每个元组包含一对键-值对

keys( )

返回一个由字典所有键构成的列表

popitem( )

删除任意键-值对,并作为两个元素的元组返回。如字典为空,则返回KeyError异常

setdefault( key [,dummvalue])

具有与get方法类似的行为。如key不在字典中,同时指定了dummvalue,就将键(key)和指定的值(dummvalue)插入字典,如果没有指定dummvalue,则值为None

update( newDictionary )

将来自newDictionary的所有键-值添加到当前字典,并覆盖同名键的值

values( )

返回字典所有值组成的一个列表

iterkeys( )

返回字典键的一个迭代器

iteritems( )

返回字典键-值对的一个迭代器

itervalues( )

返回字典值的一个迭代器

字符串方法汇总

方法 描述

string.capitalize()

把字符串的第一个字符大写

string.center(width)

返回一个原字符串居中,并使用空格填充至长度 width 的新字符串

string.count(str, beg=0, end=len(string))

返回 str 在 string 里面出现的次数,如果 beg 或者 end 指定则返回指定范围内 str 出现的次数

string.decode(encoding='UTF-8', errors='strict')

以 encoding 指定的编码格式解码 string,如果出错默认报一个 ValueError 的 异 常 , 除 非 errors 指 定 的 是 'ignore' 或 者'replace'

string.encode(encoding='UTF-8', errors='strict')

以 encoding 指定的编码格式编码 string,如果出错默认报一个ValueError 的异常,除非 errors 指定的是'ignore'或者'replace'

string.endswith(obj, beg=0, end=len(string))

检查字符串是否以 obj 结束,如果beg 或者 end 指定则检查指定的范围内是否以 obj 结束,如果是,返回 True,否则返回 False.

string.expandtabs(tabsize=8)

把字符串 string 中的 tab 符号转为空格,默认的空格数 tabsize 是 8.

string.find(str, beg=0, end=len(string))

检测 str 是否包含在 string 中,如果 beg 和 end 指定范围,则检查是否包含在指定范围内,如果是返回开始的索引值,否则返回-1

string.index(str, beg=0, end=len(string))

跟find()方法一样,只不过如果str不在 string中会报一个异常.

string.isalnum()

如果 string 至少有一个字符并且所有字符都是字母或数字则返

回 True,否则返回 False

string.isalpha()

如果 string 至少有一个字符并且所有字符都是字母则返回 True,

否则返回 False

string.isdecimal()

如果 string 只包含十进制数字则返回 True 否则返回 False.

string.isdigit()

如果 string 只包含数字则返回 True 否则返回 False.

string.islower()

如果 string 中包含至少一个区分大小写的字符,并且所有这些(区分大小写的)字符都是小写,则返回 True,否则返回 False

string.isnumeric()

如果 string 中只包含数字字符,则返回 True,否则返回 False

string.isspace()

如果 string 中只包含空格,则返回 True,否则返回 False.

string.istitle()

如果 string 是标题化的(见 title())则返回 True,否则返回 False

string.isupper()

如果 string 中包含至少一个区分大小写的字符,并且所有这些(区分大小写的)字符都是大写,则返回 True,否则返回 False

string.join(seq)

Merges (concatenates)以 string 作为分隔符,将 seq 中所有的元素(的字符串表示)合并为一个新的字符串

string.ljust(width)

返回一个原字符串左对齐,并使用空格填充至长度 width 的新字符串

string.lower()

转换 string 中所有大写字符为小写.

string.lstrip()

截掉 string 左边的空格

string.maketrans(intab, outtab])

maketrans() 方法用于创建字符映射的转换表,对于接受两个参数的最简单的调用方式,第一个参数是字符串,表示需要转换的字符,第二个参数也是字符串表示转换的目标。

max(str)

返回字符串 str 中最大的字母。

min(str)

返回字符串 str 中最小的字母。

string.partition(str)

有点像 find()和 split()的结合体,从 str 出现的第一个位置起,把 字 符 串 string 分 成 一 个 3 元 素 的 元 组 (string_pre_str,str,string_post_str),如果 string 中不包含str 则 string_pre_str == string.

string.replace(str1, str2,  num=string.count(str1))

把 string 中的 str1 替换成 str2,如果 num 指定,则替换不超过 num 次.

string.rfind(str, beg=0,end=len(string) )

类似于 find()函数,不过是从右边开始查找.

string.rindex( str, beg=0,end=len(string))

类似于 index(),不过是从右边开始.

string.rjust(width)

返回一个原字符串右对齐,并使用空格填充至长度 width 的新字符串

string.rpartition(str)

类似于 partition()函数,不过是从右边开始查找.

string.rstrip()

删除 string 字符串末尾的空格.

string.split(str="", num=string.count(str))

以 str 为分隔符切片 string,如果 num有指定值,则仅分隔 num 个子字符串

string.splitlines(num=string.count('\n'))

按照行分隔,返回一个包含各行作为元素的列表,如果 num 指定则仅切片 num 个行.

string.startswith(obj, beg=0,end=len(string))

检查字符串是否是以 obj 开头,是则返回 True,否则返回 False。如果beg 和 end 指定值,则在指定范围内检查.

string.strip([obj])

在 string 上执行 lstrip()和 rstrip()

string.swapcase()

翻转 string 中的大小写

string.title()

返回"标题化"的 string,就是说所有单词都是以大写开始,其余字母均为小写(见 istitle())

string.translate(str, del="")

根据 str 给出的表(包含 256 个字符)转换 string 的字符,

要过滤掉的字符放到 del 参数中

string.upper()

转换 string 中的小写字母为大写

string.zfill(width)

返回长度为 width 的字符串,原字符串 string 右对齐,前面填充0

string.isdecimal()

isdecimal()方法检查字符串是否只包含十进制字符。这种方法只存在于unicode对象

 

© 著作权归作者所有

粉丝 2
博文 17
码字总数 24756
作品 0
石景山
高级程序员
私信 提问
Python学习系列入门篇(二)

这些天忙的不可开交,今天终于想起来继续写,工欲善其事必先利其器,得找个markdown编辑器用一下,windows找了个破解版的(主要是可以传图片),使用起来还不错,支持实时预览,就用它了,首...

疑似一僧
2014/03/17
0
0
阿里云全球十四个节点评测分析及服务器地域选择攻略

摘要: 课程学习:零基础入门学习Python - 阿里云大学 上一期,为大家介绍了Python的入门知识——Python语言介绍、常用操作符、分支和循环。(【人生苦短,我用Python】Python免费精品课连载...

gongzuoqwe123
2017/07/27
0
0
Python快速学习02:基本数据类型 & 序列

前言   系列文章:[传送门]   也就每点一点点的开始咯,“还有两年时间,两年可以学很多东西的”      Python ['paɪθən] n. 巨蛇,大蟒     基本数据类型  变量不需要声明  ...

泥沙砖瓦浆木匠
2014/04/16
0
0
零基础学python,看完这篇文章,你的python基础就差不多了!干货【2】

运算符 3.1 算数运算符 是完成基本的算术运算使用的符号,用来处理四则运算,而“+”和“*”还可以用来处理字符串。 3.2 比较(关系)运算符 Python 2.x 中判断 不等于 还可以使用 <> 运算符...

糖宝lsh
2018/11/06
0
0
Python关于字典排序的知识讲解

1、 准备知识: 在python里,字典dictionary是内置的数据类型,是个无序的存储结构,每一元素是key-value对: 如:dict = {‘username’:‘xiaoming’,‘password’:‘123456’},其中‘u...

xieganyu3460的博客
2018/07/27
0
0

没有更多内容

加载失败,请刷新页面

加载更多

AOP的学习(1)

AOP 理解AOP编程思想(面向方法、面向切面) spring AOP的概念 方面 -- 功能 目标 -- 原有方法 通知 -- 对原有方法增强的方法 连接点 -- 可以用来连接通知的地方(方法) 切入点 -- 将用来插入...

太猪-YJ
刚刚
0
0
一张图看懂亮度、明度、光度、光亮度、明亮度

亮度、明度、光亮度,Luminance和Brightness、lightness其实都是一个意思,只是起名字太难了。 提出一个颜色模型后,由于明度的取值与别人的不同,为了表示区别所以就另想一个词而已。 因此在...

linsk1998
昨天
0
0
Python应用:python链表示例

前言 python链表应用源码示例,需要用到python os模块方法、函数和类的应用。 首先,先简单的来了解下什么是链表?链表是一种物理存储单元上非连续、非顺序的存储结构,数据元素的逻辑顺序是...

python小白1
昨天
2
0
Source Insight加载源码

Source Insight是一个图形化的源代码查看工具(当然也可以作为编译工具)。如果一个项目的源代码较多,此工具可以很方便地查找到源代码自建的依赖关系。 1.创建工程 下图为Snort源代码的文件...

天王盖地虎626
昨天
2
0
nginx-rtmp-module的缺陷分析(二)

nginx-rtmp-module使用指令push和pull来relay媒体流数据,以便分布式部署服务。 当nginx-rtmp-module作为边缘服务器(一般不会向边缘服务器推流)时,使用pull从源服务器获取媒体流数据,俗称...

YoungSagit
昨天
0
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部