Python转义字符
在需要在字符中使用特殊字符时,python用反斜杠(\)转义字符。如下表:
转义字符 | 描述 |
---|---|
\(在行尾时) | 续行符 |
\a | 响铃 |
\b | 退格(Backspace) |
\e | 转义 |
\000 | 空 |
\v | 纵向制表符 |
\t | 横向制表符 |
\r | 回车 |
\f | 换页 |
\oyy | 八进制数,yy代表的字符,例如:\o12代表换行 |
\xyy | 十六进制数,yy代表的字符,例如:\x0a代表换行 |
\other | 其它的字符以普通格式输出 |
python字符串格式化符号:
符 号 | 描述 |
---|---|
%c | 格式化字符及其ASCII码 |
%s | 格式化字符串 |
%d | 格式化整数 |
%u | 格式化无符号整型 |
%o | 格式化无符号八进制数 |
%x | 格式化无符号十六进制数 |
%X | 格式化无符号十六进制数(大写) |
%f | 格式化浮点数字,可指定小数点后的精度 |
%e | 用科学计数法格式化浮点数 |
%E | 作用同%e,用科学计数法格式化浮点数 |
%g | %f和%e的简写 |
%G | %f 和 %E 的简写 |
%p | 用十六进制数格式化变量的地址 |
Python三引号
python三引号允许一个字符串跨多行,字符串中可以包含换行符、制表符以及其他特殊字符。实例如下
实例(Python 3.0+)
以上实例执行结果为:
这是一个多行字符串的实例 多行字符串可以使用制表符 TAB ( )。 也可以使用换行符 [ ]。
三引号让程序员从引号和特殊字符串的泥潭里面解脱出来,自始至终保持一小块字符串的格式是所谓的WYSIWYG(所见即所得)格式的。
一个典型的用例是,当你需要一块HTML或者SQL时,这时用字符串组合,特殊字符串转义将会非常的繁琐。
Python 的字符串内建函数
Python 的字符串常用内建函数如下:
6 | endswith(suffix, beg=0, end=len(string)) 描述endswith() 方法用于判断字符串是否以指定后缀结尾,如果以指定后缀结尾返回True,否则返回False。可选参数"start"与"end"为检索字符串的开始与结束位置。 语法endswith()方法语法: str.endswith(suffix[, start[, end]]) 参数
返回值如果字符串含有指定的后缀返回True,否则返回False。 实例以下实例展示了endswith()方法的实例: #!/usr/bin/python3 Str='Runoob example....wow!!!' suffix='!!' print (Str.endswith(suffix)) print (Str.endswith(suffix,20)) suffix='run' print (Str.endswith(suffix)) print (Str.endswith(suffix, 0, 19)) 以上实例输出结果如下: True True False False |
7 | 把字符串 string 中的 tab 符号转为空格,tab 符号默认的空格数是 8 。 描述expandtabs() 方法把字符串中的 tab 符号('\t')转为空格,tab 符号('\t')默认的空格数是 8。 语法expandtabs()方法语法: str.expandtabs(tabsize=8) 参数
返回值该方法返回字符串中的 tab 符号('\t')转为空格后生成的新字符串。 实例以下实例展示了expandtabs()方法的实例: #!/usr/bin/python3 str = "this is\tstring example....wow!!!" print ("原始字符串: " + str) print ("替换 \\t 符号: " + str.expandtabs()) print ("使用16个空格替换 \\t 符号: " + str.expandtabs(16)) 以上实例输出结果如下: 原始字符串: this is string example....wow!!! 替换 \t 符号: this is string example....wow!!! 使用16个空格替换 \t 符号: this is string example....wow!!! |
9 | index(str, beg=0, end=len(string)) 跟find()方法一样,只不过如果str不在字符串中会报一个异常. |
10 | 如果字符串至少有一个字符并且所有字符都是字母或数字则返 回 True,否则返回 False |
11 | 如果字符串至少有一个字符并且所有字符都是字母则返回 True, 否则返回 False |
12 | 如果字符串只包含数字则返回 True 否则返回 False.. |
22 | 截掉字符串左边的空格或指定字符。 #!/usr/bin/python3 str = " this is string example....wow!!! "; print( str.lstrip() ); str = "88888888this is string example....wow!!!8888888"; print( str.lstrip('8') ); 以上实例输出结果如下: this is string example....wow!!! this is string example....wow!!!8888888 |
23 | 创建字符映射的转换表,对于接受两个参数的最简单的调用方式,第一个参数是字符串,表示需要转换的字符,第二个参数也是字符串表示转换的目标。 语法maketrans()方法语法: str.maketrans(intab, outtab) 参数
返回值返回字符串转换后生成的新字符串。 实例以下实例展示了使用maketrans() 方法将所有元音字母转换为指定的数字: #!/usr/bin/python3 intab = "aeiou" outtab = "12345" trantab = str.maketrans(intab, outtab) str = "this is string example....wow!!!" print (str.translate(trantab)) 以上实例输出结果如下: th3s 3s str3ng 2x1mpl2....w4w!!! |
26 | 把 将字符串中的 str1 替换成 str2,如果 max 指定,则替换不超过 max 次。 描述replace() 方法把字符串中的 old(旧字符串) 替换成 new(新字符串),如果指定第三个参数max,则替换不超过 max 次。 语法replace()方法语法: str.replace(old, new[, max]) 参数
返回值返回字符串中的 old(旧字符串) 替换成 new(新字符串)后生成的新字符串,如果指定第三个参数max,则替换不超过 max 次。 实例以下实例展示了replace()函数的使用方法: #!/usr/bin/python3 str = "www.w3cschool.cc" print ("菜鸟教程旧地址:", str) print ("菜鸟教程新地址:", str.replace("w3cschool.cc", "runoob.com")) str = "this is string example....wow!!!" print (str.replace("is", "was", 3)) 以上实例输出结果如下: 菜鸟教程旧地址: www.w3cschool.cc 菜鸟教程新地址: www.runoob.com thwas was string example....wow!!! |
27 | rfind(str, beg=0,end=len(string)) 类似于 find()函数,不过是从右边开始查找.返回str最后一次出现的位置。没有则返回-1 index与find的区别在于不存在时前者报异常,后者返回-1 |
32 | 按照行('\r', '\r\n', \n')分隔,返回一个包含各行作为元素的列表,如果参数 keepends 为 False,不包含换行符,如果为 True,则保留换行符。 描述Python splitlines() 按照行('\r', '\r\n', \n')分隔,返回一个包含各行作为元素的列表,如果参数 keepends 为 False,不包含换行符,如果为 True,则保留换行符。 语法splitlines()方法语法: str.splitlines([keepends]) 参数
返回值返回一个包含各行作为元素的列表。 实例以下实例展示了splitlines()函数的使用方法: >>> 'ab c\n\nde fg\rkl\r\n'.splitlines() ['ab c', '', 'de fg', 'kl'] >>> 'ab c\n\nde fg\rkl\r\n'.splitlines(True) ['ab c\n', '\n', 'de fg\r', 'kl\r\n'] >>> |
33 | startswith(str, beg=0,end=len(string)) 检查字符串是否是以 obj 开头,是则返回 True,否则返回 False。如果beg 和 end 指定值,则在指定范围内检查。 描述startswith() 方法用于检查字符串是否是以指定子字符串开头,如果是则返回 True,否则返回 False。如果参数 beg 和 end 指定值,则在指定范围内检查。 语法startswith()方法语法: str.startswith(str, beg=0,end=len(string)); 参数
返回值如果检测到字符串则返回True,否则返回False。 实例以下实例展示了startswith()函数的使用方法: #!/usr/bin/python3 str = "this is string example....wow!!!" print (str.startswith( 'this' )) print (str.startswith( 'string', 8 )) print (str.startswith( 'this', 2, 4 )) 以上实例输出结果如下: True True False |
37 | translate(table, deletechars="") 根据 str 给出的表(包含 256 个字符)转换 string 的字符, 要过滤掉的字符放到 deletechars 参数中 描述translate() 方法根据参数table给出的表(包含 256 个字符)转换字符串的字符,要过滤掉的字符放到 deletechars 参数中。 语法translate()方法语法: str.translate(table) bytes.translate(table[, delete]) bytearray.translate(table[, delete]) 参数
返回值返回翻译后的字符串,若给出了 delete 参数,则将原来的bytes中的属于delete的字符删除,剩下的字符要按照table中给出的映射来进行映射 。 实例以下实例展示了 translate() 函数的使用方法: 实例(Python 3.0+)
#!/usr/bin/python3
intab
=
"
aeiou
"
outtab
=
"
12345
"
trantab
=
str
.
maketrans
(
intab
,
outtab
)
# 制作翻译表
str
=
"
this is string example....wow!!!
"
print
(
str
.
translate
(
trantab
)
)
以上实例输出结果如下: th3s 3s str3ng 2x1mpl2....w4w!!! 以下实例演示如何过滤掉的字符 o: 实例(Python 3.0+)
#!/usr/bin/python
# 制作翻译表
bytes_tabtrans
=
bytes
.
maketrans
(
b
'
abcdefghijklmnopqrstuvwxyz
'
,
b
'
ABCDEFGHIJKLMNOPQRSTUVWXYZ
'
)
# 转换为大写,并删除字母o
print
(
b
'
runoob
'
.
translate
(
bytes_tabtrans
,
b
'
o
'
)
)
以上实例输出结果: b'RUNB' |
39 | 返回长度为 width 的字符串,原字符串右对齐,前面填充0 描述Python zfill() 方法返回指定长度的字符串,原字符串右对齐,前面填充0。 语法zfill()方法语法: str.zfill(width) 参数
返回值返回指定长度的字符串。 实例以下实例展示了 zfill()函数的使用方法: #!/usr/bin/python3 str = "this is string example from runoob....wow!!!" print ("str.zfill : ",str.zfill(40)) print ("str.zfill : ",str.zfill(50)) 以上实例输出结果如下: str.zfill : this is string example from runoob....wow!!! str.zfill : 000000this is string example from runoob....wow!!! |
字符串的分割还有partition()这种方式。
partition(sep) --> (head,sep,tail)
从左向右遇到分隔符把字符串分割成两部分,返回头、分割符、尾三部分的三元组。如果没有找到分割符,就返回头、尾两个空元素的三元组。
s1 = "I'm a good sutdent." #以'good'为分割符,返回头、分割符、尾三部分。 s2 = s1.partition('good') #没有找到分割符'abc',返回头、尾两个空元素的元组。 s3 = s1.partition('abc') print(s1) print(s2) print(s3)
结果如下:
I'm a good sutdent.
("I'm a ", 'good', ' sutdent.')
("I'm a good sutdent.", '', '')