文章目录
- 1. 字符串常用方法
- 2. 字符串格式化
- 2.1 字符串格式化符号含义
- 2.2 格式化操作符辅助命令
- 2.3 format用法
- 2.4 format_map用法
1. 字符串常用方法
字符串方法 | 注释 |
capitalize() | 把字符串的第一个字符改为大写 |
center(width) | 将字符串居中,并使用空格填充至长度 width 的新字符串 |
count(sub[, start[, end]]) | 返回 sub 在字符串里边出现的次数,start 和 end 参数表示范围,可选 |
endswith(sub[, start[, end]]) | 检查字符串是否以 sub 子字符串结束,如果是返回 True,否则返回 False。start 和 end 参数表示范围,可选 |
find(sub[, start[, end]]) | 检测 sub 是否包含在字符串中,如果有则返回第一个查到的索引值,否则返回 -1,start 和 end 参数表示范围,可选 |
index(sub[, start[, end]]) | 跟 find 方法一样,不过如果 sub 不在 string 中会产生一个异常 |
isalnum() | 如果字符串至少有一个字符并且所有字符都是字母或数字则返回 True,否则返回 False |
isalpha() | 如果字符串至少有一个字符并且所有字符都是字母则返回 True,否则返回 False |
isdecimal() | 如果字符串只包含十进制数字则返回 True,否则返回 False |
isdigit() | 如果字符串只包含数字则返回 True,否则返回 False |
islower() | 如果字符串中至少包含一个区分大小写的字符,并且这些字符都是小写,则返回 True,否则返回 False |
isspace() | 如果字符串中只包含空格,则返回 True,否则返回 False |
istitle() | 如果字符串是标题化(所有的单词都是以大写开始,其余字母均小写),则返回 True,否则返回 False |
isupper() | 如果字符串中至少包含一个区分大小写的字符,并且这些字符都是大写,则返回 True,否则返回 False |
join(sub) | 以字符串作为分隔符,插入到 sub 中所有的字符之间 |
string.lower() | 转换字符串中所有大写字符为小写 |
string.lstrip() | 去掉字符串左边的所有空格 |
partition(sub) | 找到子字符串 sub,把字符串分成一个 3 元组 (pre_sub, sub, fol_sub),如果字符串中不包含 sub 则返回 (‘原字符串’, ‘’, ‘’) |
replace(old, new[, count]) | 把字符串中的 old 子字符串替换成 new 子字符串,如果 count 指定,则替换不超过 count 次 |
rfind(sub[, start[, end]]) | 类似于 find() 方法,不过是从右边开始查找 |
rindex(sub[, start[, end]]) | 类似于 index() 方法,不过是从右边开始 |
rstrip() | 删除字符串末尾的空格 |
split(sep=None, maxsplit=-1) | 不带参数默认是以空格为分隔符切片字符串,如果 string.maxsplit 参数有设置,则仅分隔 maxsplit 个子字符串,返回切片后的子字符串拼接的列表。 |
splitlines(([keepends])) | 在输出结果里是否去掉换行符,默认为 False,不包含换行符;如果为 True,则保留换行符。返回一个包含各行作为元素的列表。 |
startswith(prefix[, start[, end]]) | 检查字符串是否以 prefix 开头,是则返回 True,否则返回 False。start 和 end 参数可以指定范围检查,可选 |
strip([chars]) | 删除字符串前边和后边所有的空格,chars 参数可以定制删除的字符,可选 |
swapcase() | 翻转字符串中的大小写 |
title() | 返回标题化(所有的单词都是以大写开始,其余字母均小写)的字符串 |
translate(table) | 根据 table 的规则(可以由 str.maketrans(‘a’, ‘b’) 定制)转换字符串中的字符 |
upper() | 转换字符串中的所有小写字符为大写 |
1. replace和translate区别
translate函数和replace函数一样,用于替换字符串中的某个部分,但是和replace不同,translate只处理单个字符,而且可以同时进行多个替换。在使用translate函数转换之前,需要一张转换表,转换表中是以某个字符替换某个字符的对应关系,这个表中有256个字符,我们可以通过使用string模块中的maketrans函数简化这一操作
>>> table = str.maketrans('iu','ui')
>>> print("i love u".translate(table))
u love i
2. join用法
- 如何将列表中的元素拼接成一个字符串
>>> words = ["I", "love", "Python", "&", "FishC"]
>>> print(" ".join(words),end = ".")
I love Python & FishC.
2. 字符串格式化
2.1 字符串格式化符号含义
符号 | 说明 |
%c | 格式化字符及其 ASCII 码 |
%s | 格式化字符串 |
%d | 格式化整数 |
%o | 格式化无符号八进制数 |
%x | 格式化无符号十六进制数 |
%X | 格式化无符号十六进制数(大写) |
%f | 格式化浮点数字,可指定小数点后的精度 |
%e | 用科学计数法格式化浮点数 |
%E | 作用同 %e,用科学计数法格式化浮点数 |
%g | 根据值的大小决定使用 %f 或 %e |
%G | 作用同 %g,根据值的大小决定使用 %f 或者 %E |
2.2 格式化操作符辅助命令
符号 | 说明 |
m.n | m 是显示的最小总宽度,n 是小数点后的位数 |
- | 用于左对齐 |
+ | 在正数前面显示加号(+) |
# | 在八进制数前面显示 ‘0o’,在十六进制数前面显示 ‘0x’ 或 ‘0X’ |
0 | 显示的数字前面填充 ‘0’ 取代空格 |
2.3 format用法
- 位置索引和关键字索引
#位置索引-自动编号
>>> "{} {} {}{}".format('一','粒','尘 埃','。')
'一 粒 尘 埃。'
#关键字索引
>>> "{a} {b} {c}{d}".format(a='一',b='粒',c='尘 埃',d='。')
'一 粒 尘 埃。'
2.4 format_map用法
>>> d = {'a':'一','b':'粒','c':'尘','d':'埃'}
>>> print('{a} {b} {c} {d}'.format_map(d))
一 粒 尘 埃