首页 > 编程语言 > 详细

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

时间:2015-09-05 23:56:54      阅读:537      评论:0      收藏: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对象

 

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

原文:http://my.oschina.net/aiyungui/blog/501446

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!