List定义及常用的方法见上一篇博客。

Tuple

元组tuple的定义:

tuple是一个有序的元素组成的不可变对象的集合,使用小括号()表示,是可迭代对象

元组中数据的访问

支持索引(下标访问)

正负所有索引不可以超界,否则引起IndexError报错

元组通过索引访问

tuple[index] ,index就是索引,使用中括号访问

index(value,[value,[start,stop]])

index是使用值查找,从指定区间指定区间查找元组内的元素是否匹配,匹配到第一个就立即返回索引,找不到就抛出valueError异常时间复杂度为O(n)

count(value)

返回元组中值的个数,需要遍历整个元组,时间复杂都为O(n)

len(tuple)

返回元组中元素的个数。


由于元组是只读的,所以增,改,删方法都没有

字符串


字符串的定义

字符串是一个个字符的集合,是一个有序的序列,使用单引号,双引号,三引号引住的字符序列,字符串是不可变对象,可以索引,可以迭代。从python3起,字符串是Unicode类型

字符串元素的访问可通过下标访问。

字符串的连接

join()“string”.join(iterable)

将可迭代对象连接起来,使用指定的string作为分割符,返回一个新的字符串

+

将两个字符串连接起来,生成一个新的字符串,空间占用翻倍

字符串的分割分成两部分split系和partition系

split :将字符串按照分割符分割成若个个字符串,并返回列表。

split(seq=None,maxaplit=)是从左至右进行切割,可以指定分割字符串,在不指定的情况下默认是空白字符左分割符,还可以指定分割的次数,-1表示遍历整个字符串

rsplit (seq=None,maxsplit=-1)是从右至左进行切割,用法同split一样。

splitlines([keepends]) 是按照行来进行切分字符串,keepends指的是否保留行分割符,行分割符包括\n,\r\n,\r

partition:将字符串按照分割符分割成两端,返回2段和分割符的元组

partition(seq):从左至右,遇到分割符就把字符串分割为两部分,返回头,分隔符,尾三部分的三元组,没有找到分割符,就返回头,空的分割,空尾的三元组。必须指定seq

Rpartition(seq):从右至左,遇到分割符就把字符串分割成两部分,和partition用法一样。

字符串针对于英文的一些方法:

upper() 全大写

lower() 全小写

swapcase() 交换大小写

title() 标题的每个单词都大写

capitalized()首个单词大写

center(width[,fillchar]) 以长度为宽度的字符串为中心返回,使用指定的fillchar完成填充

zfill(width) 返回一个字符串,左边右ASCII ‘0’填充的字符串,居右,左边右0填充。

ljust(width[,fillchar]) 左对齐

rjust(width[,fillchar]) 右对齐

字符串的查找及修改(字符串不可变,原字符串不修改)

“修改”:

replace(old,new,[,count])字符串中找到匹配替换为新字串,放回新字符串,可以指定替换几次,不指定就是所有匹配的都替换

strip([chars])从字符串两端去除指定的字符集chars中的所有字符,不指定chats,去除两端的空白字符

lstrip([chars])从左边开始

rstrip ([chars]) 从右边开始

字符串的查找:

find(sub[,start[,end]])

在指定的区间[start,end],从左至右,查找字串sub.找到返回索引,没找到放回-1

rfind(sub[,start[,end]])

在指定的区间从右至左,和find一样

index(sub[,start[,end]])

在指定的区间[start,end],从左至右,查找字串sub,找到返回索引,没找到就抛出异常valueError

rIndex(sub[,start[,end]])

在指定的区间[start,end]从左至右,查找字串sub,和index使用一样

len() 返回字符串中字符的个数

count(sub[,start[,end]])

在指定的区间[start,[end]],从左至右,统计字串sub出现的次数


字符串的判断:

endswith(suffix[,start[,end]])

在指定的区间,字符串是否是suffix结尾

startswith(prefix[,start[,end]])

在指定的区间[start,end],字符串是否是prefix开头

isalnum() 是否是数字和字母的组成

isalpha() 是否是字母

isdecimal() 是否只包含十进制数字

isdigit() 是否全部是数字(0~9)

isifentifier() 是不是字母和下划线开头,其他都是字母,数字,下划线

islower 是否都是小写

isupper() 是否都是大写

isspace() 是否只包含空白字符

字符串的格式化:

在python3中,字符串的格式化鼓励使用format()函数

format()函数格式字符串语法

“{}{XXX}”.format(*args,**kwargs) 返回一个字符串args是位置参数,是一个元组,kwargs是关键字参数,是一个字典。花括号表示占位符,{}表示按照顺序匹配位置参数,{n}表示取位置参数索引位n的值。{XXX}表示在关键字参数中搜索名称一致的。{{}}表示打印花括号。

format()函数中使用的参数

位置参数

就是按照位置顺序用位置参数替换前面的格式化字符串的占位符

关键字符参数或命名参数

位置参数按照序号匹配,关键字参数按照名称匹配

访问元素

“{0[0].}{0[1]}’.format((‘www’,’dsfa’))

对象属性访问

可以直接访问对象的属性

可以直接使用对齐方式:

< 左对齐

>右对齐

^居中对齐


List

tuple

字符串

可变对象

不可变对象

不可变对象

使用[]

使用()

使用‘’,“”,“”“”

可迭代对象

可迭代对象

可迭代对象

有序的序列,可以索引

有序的序列,可以索引

有序的序列,可以索引

index(value,[start,[ends]])

index(value,[start,[ends]])

index(sub,[start,[ends]]) rIndex(sub,[start,[ends]])

find(sub,[start,[ends]])

rfind(sub,[start,[ends]])

count(value)

count(value)

count(sub,[start,[ends]])

len(list)

len(tuple)

len(str)

append(object)


replace(old,new,[,count])

insert(index,object)


lstrip([chars])

rstrip ([chars])

extend(iteratable)



+


+

*


*

remove()



pop()



clear()



reverse()



sort()



in

in

in



join



split()



rsplit()



splitlines()



partition()



rpartition()



upper()



lower()



swapcase()



Title(),capitalize(),center(),zfill(),ljust(),rjust()