【3】python核心编程 第六章-序列:字符串、列表和元组

1、序列类型操作符

1 序列操作符 作用
2 seq[ind] 获得下标为ind 的元素
3 seq[ind1:ind2] 获得下标从ind1 到ind2 间的元素集合
4 seq * expr 序列重复expr 次
5 seq1 + seq2 连接序列seq1 和seq2
6 obj in seq 判断obj 元素是否包含在seq 中
7 obj not in seq 判断obj 元素是否不包含在seq 中

2、序列类型可用的内建函数

 1 函数名 功能
 2 enumerate(iter)  接受一个可迭代对象作为参数,返回一个enumerate 对象(同
 3 时也是一个迭代器),该对象生成由iter 每个元素的index 值
 4 和item 值组成的元组(PEP 279)
 5 len(seq) 返回seq 的长度
 6 max(iter,key=None) or
 7 max(arg0,arg1...,key=None)b 返回iter 或(arg0,arg1,...)中的最大值,如果指定了key,
 8 这个key 必须是一个可以传给sort()方法的,用于比较的回
 9 调函数.
10 min(iter, key=None) or
11 min(arg0, arg1.... key=None) 返回iter 里面的最小值;或者返回(arg0,arg2,...)里面的最小值;如果指定了key,这个key 必须是一个可以传给
12 sort()方法的,用于比较的回调函数.
13 reversed(seq)c 接受一个序列作为参数,返回一个以逆序访问的迭代器(PEP 322)
14 sorted(iter,
15 func=None,
16 key=None,
17 reverse=False)c 接受一个可迭代对象作为参数,返回一个有序的列表;可选参数
18 func,key 和reverse 的含义跟list.sort()内建函数的参数含义一
19 样.
20 sum(seq, init=0)a 返回seq 和可选参数init 的总和, 其效果等同于
21 reduce(operator.add,seq,init)
22 zip([it0, it1,... itN])d 返回一个列表,其第一个元素是it0,it1,...这些元素的第
23 一个元素组成的一个元组,第二个...,类推.

3、 string 模块预定义的字符串

1 >>> import string
2 >>> string.ascii_uppercase
3 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'
4 >>> string.ascii_lowercase
5 'abcdefghijklmnopqrstuvwxyz'
6 >>> string.ascii_letters
7 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ'
8 >>> string.digits
9 '0123456789'

4、性能

 1 一般来说,从性能的的角度来考虑,把重复操作作为参数放到循环里面进行是非常低效的.
 2 while i < len(myString):
 3 print 'character %d is:', myString[i]
 4 上面的循环操作把大把的时间都浪费到了重复计算字符串myString 的长度上了.每次循环
 5 迭代都要运行一次这个函数.如果把这个值做一次保存,我们就可以用更为高效的方式重写我们
 6 的循环操作.
 7 length = len(myString)
 8 while i < length:
 9 print 'character %d is:', myString[i]
10 这个方法同样适用于上面的例6.1
11 for otherChar in myInput[1:]:
12 if otherChar not in alphas + nums:

5、zip()

1 >>> s, t = 'foa', 'obr'
2 >>> zip(s, t)
3 [('f', 'o'), ('o', 'b'), ('a', 'r')]

6、字符串内建函数

 1 方法 描述
 2 string.capitalize() 把字符串的第一个字符大写
 3 string.center(width) 返回一个原字符串居中,并使用空格填充至长度width 的新字符
 4  5 string.count(str, beg=0,
 6 end=len(string)) 返回str 在string 里面出现的次数,如果beg 或者end 指定则
 7 返回指定范围内str 出现的次数
 8 string.decode(encoding='UTF-8',
 9 errors='strict') 以encoding 指定的编码格式解码string,如果出错默认报一个
10 ValueError 的异常, 除非errors 指定的是'ignore' 或者
11 'replace'
12 string.encode(encoding='UTF-8',
13 errors='strict')a 以encoding 指定的编码格式编码string,如果出错默认报一个
14 ValueError 的异常,除非errors 指定的是'ignore'或者'replace'
15 string.endswith(obj, beg=0,
16 end=len(string))b,e 检查字符串是否以obj 结束,如果beg 或者end 指定则检查指
17 定的范围内是否以obj 结束,如果是,返回True,否则返回False.
18 string.expandtabs(tabsize=8)把字符串string 中的tab 符号转为空格,默认的空
19 格数tabsize 是8.
20 string.find(str, beg=0,
21 end=len(string)) 检测str 是否包含在string 中,如果beg 和end 指定范围,
22 则检查是否包含在指定范围内,如果是返回开始的索引值,否则
23 返回-1
24 string.index(str, beg=0,
25 end=len(string)) 跟find()方法一样,只不过如果str 不在string 中会报一个异常.
26 string.isalnum()a, b, c R 如果string 至少有一个字符并且所有字符都是字母或数字则返
27 回True,否则返回False
28 string.isalpha()a, b, c 如果string 至少有一个字符并且所有字符都是字母则返回True,
29 否则返回False
30 string.isdecimal()b, c, d 如果string 只包含十进制数字则返回True 否则返回False.
31 string.isdigit()b, c 如果string 只包含数字则返回True 否则返回False.
32 string.islower()b, c 如果string 中包含至少一个区分大小写的字符,并且所有这些(区分
33 大小写的)字符都是小写,则返回True,否则返回False
34 string.isnumeric()b, c, d 如果string 中只包含数字字符,则返回True,否则返回False
35 string.isspace()b, c 如果string 中只包含空格,则返回True,否则返回False.
36 string.istitle()b, c 如果string 是标题化的(见title())则返回True,否则返回False
37 string.isupper()b, c 如果string 中包含至少一个区分大小写的字符,并且所有这些(区分
38 大小写的)字符都是大写,则返回True,否则返回False
39 string.join(seq) Merges (concatenates)以string 作为分隔符,将seq 中所有的元素
40 (的字符串表示)合并为一个新的字符串
41 string.ljust(width)返回一个原字符串左对齐,并使用空格填充至长度width 的新字符串
42 string.lower() 转换string 中所有大写字符为小写.
43 string.lstrip() 截掉string 左边的空格
44 string.partition(str)e 有点像find()和split()的结合体,从str 出现的第一个位置起,
45 把字符串string 分成一个3 元素的元组
46 (string_pre_str,str,string_post_str),如果string 中不包含
47 str 则string_pre_str == string.
48 string.replace(str1, str2,
49 num=string.count(str1))把string 中的str1 替换成str2,如果num 指定,
50 则替换不超过num 次.
51 string.rfind(str, beg=0,end=len(string))类似于find()函数,不过是从右边开始查
52 找.
53 string.rindex( str, beg=0,end=len(string)) 类似于index(),不过是从右边开始.
54 string.rjust(width)返回一个原字符串右对齐,并使用空格填充至长度width 的新字符串
55 string.rpartition(str)e 类似于partition()函数,不过是从右边开始查找.
56 string.rstrip() 删除string 字符串末尾的空格.
57 string.split(str="", num=string.count(str)) 以str 为分隔符切片string,如果num
58 有指定值,则仅分隔num 个子字符串
59 string.splitlines(num=string.count('
'))b, c 按照行分隔,返回一个包含各行作为元素
60 的列表,如果num 指定则仅切片num 个
61 行.
62 string.startswith(obj, beg=0,end=len(string))b, e 检查字符串是否是以obj 开头,是则
63 返回True,否则返回False。如果
64 beg 和end 指定值,则在指定范围内检查
65 string.strip([obj]) 在string 上执行lstrip()和rstrip()
66 string.swapcase() 翻转string 中的大小写
67 string.title()b, c 返回"标题化"的string,就是说所有单词都是以大写开始,其余
68 字母均为小写(见istitle())
69 string.translate(str, del="") 根据str 给出的表(包含256 个字符)转换string 的字符,
70 要过滤掉的字符放到del 参数中
71 string.upper() 转换string 中的小写字母为大写
72 string.zfill(width) 返回长度为width 的字符串,原字符串string 右对齐,前面填充0

7、与字符串类型有关的模块

 1 模块 描述
 2 string 字符串操作相关函数和工具,比如Template 类.
 3 re 正则表达式:强大的字符串模式匹配模块
 4 struct 字符串和二进制之间的转换
 5 c/StringIO 字符串缓冲对象,操作方法类似于file 对象.
 6 base64 Base 16,32,64 数据编解码
 7 codecs 解码器注册和基类
 8 crypt 进行单方面加密
 9 difflib 找出序列间的不同
10 hashlib 多种不同安全哈希算法和信息摘要算法的API
11 hma HMAC 信息鉴权算法的Python 实现
12 md5 RSA 的MD5 信息摘要鉴权
13 rotor 提供多平台的加解密服务
14 sha NIAT 的安全哈希算法SHA
15 stringprep 提供用于IP 协议的Unicode 字符串
16 textwrap 文本打包和填充
17 unicodedata Unicode 数据库

8、列表类型内建函数

 1 List Method Operation
 2 list.append(obj) 向列表中添加一个对象obj
 3 list.count(obj) 返回一个对象obj 在列表中出现的次数
 4 list.extend(seq) 把序列seq 的内容添加到列表中
 5 list.index(obj, i=0,
 6 j=len(list)) 返回list[k] == obj 的k 值,并且k 的范围在 i<=k<j;否则
 7 引发ValueError 异常.
 8 list.insert(index, obj) 在索引量为index 的位置插入对象obj.
 9 list.pop(index=-1) 删除并返回指定位置的对象,默认是最后一个对象
10 list.remove(obj) 从列表中删除对象obj
11 list.reverse() 原地翻转列表
12 list.sort(func=None,key=None,reverse=False) 以指定的方式排序列表中的成员,如果func 和key 参数指定,
13 则按照指定的方式比较各个元素,如果reverse 标志被置为
14 True,则列表以反序排列.
原文地址:https://www.cnblogs.com/jakeyChen/p/4873653.html