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+)
#!/usr/bin/python3
para_str = """ 这是一个多行字符串的实例
多行字符串可以使用制表符
TAB ( \t )。
也可以使用换行符 [ \n ]。
"""
print ( para_str )
以上实例执行结果为:
这是一个多行字符串的实例
多行字符串可以使用制表符
TAB ( )。
也可以使用换行符 [
]。
三引号让程序员从引号和特殊字符串的泥潭里面解脱出来,自始至终保持一小块字符串的格式是所谓的WYSIWYG(所见即所得)格式的。
一个典型的用例是,当你需要一块HTML或者SQL时,这时用字符串组合,特殊字符串转义将会非常的繁琐。
errHTML = '''
<HTML><HEAD><TITLE>
Friends CGI Demo</TITLE>
</HEAD><BODY><H3>ERROR</H3>
<B>%s</B><P>
<FORM><INPUT TYPE=button VALUE=BackONCLICK="window.history.back()"></FORM>
</BODY></HTML>
'''
cursor . execute ( '''
CREATE TABLE users (
login VARCHAR(8),
uid INTEGER,
prid INTEGER)
''' )
Python 的字符串内建函数
Python 的字符串常用内建函数如下:
6 | endswith(suffix, beg=0, end=len(string))检查字符串是否以 obj 结束,如果beg 或者 end 指定则检查指定的范围内是否以 obj 结束,如果是,返回 True,否则返回 False. 描述endswith() 方法用于判断字符串是否以指定后缀结尾,如果以指定后缀结尾返回True,否则返回False。可选参数"start"与"end"为检索字符串的开始与结束位置。 语法endswith()方法语法:
参数
返回值如果字符串含有指定的后缀返回True,否则返回False。 实例以下实例展示了endswith()方法的实例:
以上实例输出结果如下:
|
7 | 把字符串 string 中的 tab 符号转为空格,tab 符号默认的空格数是 8 。 描述expandtabs() 方法把字符串中的 tab 符号('\t')转为空格,tab 符号('\t')默认的空格数是 8。 语法expandtabs()方法语法:
参数
返回值该方法返回字符串中的 tab 符号('\t')转为空格后生成的新字符串。 实例以下实例展示了expandtabs()方法的实例:
以上实例输出结果如下:
|
9 | index(str, beg=0, end=len(string)) 跟find()方法一样,只不过如果str不在字符串中会报一个异常. |
10 | 如果字符串至少有一个字符并且所有字符都是字母或数字则返 回 True,否则返回 False |
11 | 如果字符串至少有一个字符并且所有字符都是字母则返回 True, 否则返回 False |
12 | 如果字符串只包含数字则返回 True 否则返回 False.. |
22 | 截掉字符串左边的空格或指定字符。
以上实例输出结果如下:
|
23 | 创建字符映射的转换表,对于接受两个参数的最简单的调用方式,第一个参数是字符串,表示需要转换的字符,第二个参数也是字符串表示转换的目标。 语法maketrans()方法语法:
参数
返回值返回字符串转换后生成的新字符串。 实例以下实例展示了使用maketrans() 方法将所有元音字母转换为指定的数字:
以上实例输出结果如下:
|
26 | 把 将字符串中的 str1 替换成 str2,如果 max 指定,则替换不超过 max 次。 描述replace() 方法把字符串中的 old(旧字符串) 替换成 new(新字符串),如果指定第三个参数max,则替换不超过 max 次。 语法replace()方法语法:
参数
返回值返回字符串中的 old(旧字符串) 替换成 new(新字符串)后生成的新字符串,如果指定第三个参数max,则替换不超过 max 次。 实例以下实例展示了replace()函数的使用方法:
以上实例输出结果如下:
|
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()方法语法:
参数
返回值返回一个包含各行作为元素的列表。 实例以下实例展示了splitlines()函数的使用方法:
|
33 | startswith(str, beg=0,end=len(string)) 检查字符串是否是以 obj 开头,是则返回 True,否则返回 False。如果beg 和 end 指定值,则在指定范围内检查。 描述startswith() 方法用于检查字符串是否是以指定子字符串开头,如果是则返回 True,否则返回 False。如果参数 beg 和 end 指定值,则在指定范围内检查。 语法startswith()方法语法:
参数
返回值如果检测到字符串则返回True,否则返回False。 实例以下实例展示了startswith()函数的使用方法:
以上实例输出结果如下:
|
37 | translate(table, deletechars="") 根据 str 给出的表(包含 256 个字符)转换 string 的字符, 要过滤掉的字符放到 deletechars 参数中 描述translate() 方法根据参数table给出的表(包含 256 个字符)转换字符串的字符,要过滤掉的字符放到 deletechars 语法translate()方法语法:
参数
返回值返回翻译后的字符串,若给出了 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 ) ) 以上实例输出结果如下:
以下实例演示如何过滤掉的字符 o: 实例(Python 3.0+)#!/usr/bin/python # 制作翻译表 bytes_tabtrans = bytes . maketrans ( b ' abcdefghijklmnopqrstuvwxyz ' , b ' ABCDEFGHIJKLMNOPQRSTUVWXYZ ' ) # 转换为大写,并删除字母o print ( b ' runoob ' . translate ( bytes_tabtrans , b ' o ' ) ) 以上实例输出结果:
|
39 | 返回长度为 width 的字符串,原字符串右对齐,前面填充0 描述Python zfill() 方法返回指定长度的字符串,原字符串右对齐,前面填充0。 语法zfill()方法语法:
参数
返回值返回指定长度的字符串。 实例以下实例展示了 zfill()函数的使用方法:
以上实例输出结果如下:
|
字符串的分割还有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.", '', '')