洗礼灵魂,修炼python(9)--灵性的字符串

python几大核心之——字符串

1.什么是字符串

其实前面说到数据类型时说过了,就是带有引号的参数,“”引号内的一切东西就是字符串,字符串又叫文本。

2.创建字符串的两种方式:

3.字符串的方法:

 python2:

python3:

同样的,不同版本里字符串的方法还是很多不一样,老套路,我还是只解析常用的:capitalize,casefold.center,count,decode,encode,endswith,expandtabs,find,format,index,isalnum,isalpha,isdigit,isidentifier,islower,isspace,istitle,isupper,join,ljust,lower,lstrip,partition,replace,rfind,rindex,rjust,rpartition,rpslit,rstrip,split,splitines,startwith,strip', swapcase, title, translate, upper, zfill(是不是有点多,是的,因为字符串在实际的开发中最常用,所以方法用的也多)

captalize:把整个字符串的第一个单词的首字母大写并返回

但注意的是,字符串是不可变对象,所以不改变自身

casefold:把整个字符串的所有字符改为小写,python3里特有的

center(width):把字符串居中,并使用空格填充至长度 width 的新字符串

 

count(sub[, start[, end]]):返回 sub 在字符串里边出现的次数,start 和 end 参数表示范围,前面的集合等使用过,不再演示

decode(decode='strict'):把已知的编码方式解码为Unicode,前面解释过,在python3里不再有此方法

encode(encoding='utf-8', errors='strict'):以 encoding 指定的编码格式对字符串进行编码,前面解释过
在python3不需要decode再encode,直接使用encode:

endswith(sub[, start[, end]]):检查字符串是否以 sub 子字符串结束,如果是返回 True,否则返回 False。start 和 end 参数表示范围,可选

 startswith(prefix[, start[, end]]):检查字符串是否以 prefix 开头,是则返回 True,否则返回 False。start 和 end 参数可以指定范围检查,可选

expandtabs([tabsize=8]):把字符串中的 tab 符号( )转换为空格,如不指定参数,默认的空格数是 tabsize=8

这个没法看出效果,自己动手操作体会吧


find(sub[, start[, end]]):检测 sub 是否包含在字符串中,如果有则返回索引值,否则返回 -1,start 和 end 参数表示范围,可选

rfind(sub[, start[, end]]):类似于 find() 方法,不过是从右边开始查找

foramt:格式化字符串(详见下面第6点)


index(sub[, start[, end]]):跟 find 方法一样,不过如果 sub 不在 string 中会产生一个异常

rindex(sub[, start[, end]]):类似于 index() 方法,不过是从右边开始


isalnum():如果字符串至少有一个字符并且所有字符都是字母或数字则返回 True,否则返回 False

前者因为含有逗号和空格,所以False


isalpha():如果字符串至少有一个字符并且所有字符都是字母则返回 True,否则返回 False

前者含有空格


isdecimal():如果字符串只包含十进制数字则返回 True,否则返回 False,这是python3特有


isdigit():如果字符串只包含数字则返回 True,否则返回 False

isnumeric():如果字符串中只包含数字字符,则返回 True,否则返回 False,和上面的isdigit方法相同,不再演示


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


isspace():如果字符串中只包含空格,则返回 True,否则返回 False


istitle():如果字符串是标题化(所有的单词都是以大写开始,其余字母均小写),则返回 True,否则返回 False


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


join(sub):以字符串作为分隔符,插入到 sub 中所有的字符之间


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


lower():转换字符串中所有大写字符为小写。

partition(sub):找到子字符串 sub,把字符串分成一个 3 元组 (pre_sub, sub, fol_sub),如果字符串中不包含 sub 则返回 ('原字符串', '', '')

rpartition(sub):类似于 partition() 方法,不过是从右边开始查找


replace(old, new[, count]):把字符串中的 old 子字符串替换成 new 子字符串,如果 count 指定,则替换不超过 count 次

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


split(sep=None, maxsplit=-1):不带参数默认是以空格为分隔符切片字符串,如果 maxsplit 参数有设置,则仅分隔 maxsplit 个子字符串,返回切片后的子字符串拼接的列表



splitlines(([keepends])):按照 ' ' 分隔,返回一个包含各行作为元素的列表,如果 keepends 参数指定,则返回前 keepends 行


strip([chars]):删除字符串前边和后边所有的空格,chars 参数可以定制删除的字符,可选

lstrip():去掉字符串左边的所有空格

rstrip():删除字符串末尾(右边)的空格。


swapcase():翻转字符串中的大小写


title():返回标题化(所有的单词都是以大写开始,其余字母均小写)的字符串


translate(table):根据 table 的规则(可以由 str.maketrans('a', 'b') 定制,maketrans方法是python特有,用的较少)转换字符串中的字符


upper():转换字符串中的所有小写字符为大写


zfill(width):返回长度为 width 的字符串,原字符串右对齐,前边用 0 填充

4.字符串也可以被看作一个不可变的列表

 怎么说?请看:

5.字符串也可以切片

6.字符串拼接到字符串格式化

字符串拼接就是把多个字符串对象用符号【+】拼接起来

 

但是不同类型的对象是不能拼接的,比如:

其实还有个问题,用+拼接是有点万恶的,为什么叫万恶,比如:

还是这个例子,有没有发现【yangI】是连在一起的,不过你可以这样:

手动在前面加个逗号,但是如果要处理很大的数据,这样是手动搞很麻烦的,开发程序还要耗时间来搞这种毫无技术含量有费时的问题是万恶的

所以,换一种方式,格式化,格式化字符串是最常用的,格式化在数据类型提到了一点点,说,只要【%】符号遇到字符串,这符号就不再是取余。具体的符号和对应的含义请看下面:

%c:格式化字符及其 ASCII 码
%s:格式化字符串
%d:格式化整数
%o:格式化无符号八进制数
%x:格式化无符号十六进制数
%X:格式化无符号十六进制数(大写)
%f:格式化浮点数字,可指定小数点后的精度
%e:用科学计数法格式化浮点数
%E:作用同 %e,用科学计数法格式化浮点数
%g:根据值的大小决定使用 %f 或 %e
%G:作用同 %g,根据值的大小决定使用 %f 或者 %E

实例:多种方式打印【I love python】

说到这,就得把字符串格式化相关的都摆出来:

格式化操作符辅助命令:

*      	定义宽度或者小数点精度
-      	用做左对齐
+      	在正数前面显示加号( + )
<sp> 	在正数前面显示空格
#    	在八进制数前面显示零('0'),在十六进制前面显示'0x'或者'0X'(取决于用的是'x'还是'X')
0      	显示的数字前面填充`0`而不是默认的空格
%     	'%%'输出一个单一的'%'
var)  	映射变量(字典参数)
m.n.  	m是显示的最小总宽度,n是小数点后的位数(如果可用的话)
原文地址:https://www.cnblogs.com/Eeyhan/p/7617535.html