一、Python 字符串
维基百科:字符串是由零个或多个字符组成的有限序列。而在Python 3中,它有着更明确的意思:字符串是由Unicode码点组成的不可变序列。
字符串序列是一种不可变序列,这意味着它不能像可变序列一能,进行就地修改。例如,在字符串 “Python” 的基础上拼接 “Cat”,得到字符串“PythonCat”,新的字符串是一个独立的存在,它与基础字符串 “Python” 并没有关联关系。
basename = "Python"
myname = basename + "Cat"
id(basename) == id(myname) # False
字符串是用单引号"或双引号""括起来一串字符。使用三引号创建多行字符串。Python 不支持单字符类型,单字符在 Python 中也是作为一个字符串使用。
>>> var1 = 'Hello World!'
>>> var2 = "Jack"
>>> var3 = "" # 空字符串
>>> var4 = "it's apple" # 双引号中可以嵌套单引号
>>> var5 = 'This is "PLANE"!' # 单引号中可以嵌套双引号
>>> var6 = 'what is 'your'name'
SyntaxError: invalid syntax
但是单引号嵌套单引号或者双引号嵌套双引号就会出现歧义。
二、Python 字符串运算符
下表实例变量 a 值为字符串 “Hello”,b 变量值为 “Python”:
操作符 | 描述 | 实例 |
+ | 字符串连接 | a + b ‘HelloPython’ |
* | 重复输出字符串 | a * 2 ‘HelloHello’ |
[] | 通过索引获取字符串中字符 | a[1] ‘e’ |
[ : ] | 截取字符串中的一部分 | a[1:4] ‘ell’ |
in | 成员运算符 - 如果字符串中包含给定的字符返回 True | “H” in a True |
not in | 成员运算符 - 如果字符串中不包含给定的字符返回 True | “M” not in a True |
r/R | 原始字符串 - 原始字符串:所有的字符串都是直接按照字面的意思来使用,没有转义特殊或不能打印的字符。 原始字符串除在字符串的第一个引号前加上字母"r"(可以大小写)以外,与普通字符串有着几乎完全相同的语法。 | Print(r’\n’) \n Print(R’\n’) \n |
% | 格式字符串 | 请看输入与输出 |
三、Python字符串切片操作
• 从左到右索引默认0开始的,最大范围是字符串长度少1
• 从右到左索引默认-1开始的,最大范围是字符串开头
• [头下标:尾下标] 获取的子字符串包含头下标的字符,但不包含尾下标的字符。
比如:
>>> s = 'abcdef'
>>> s[1:5]
'bcde'
Python 列表截取可以接收第三个参数,参数作用是截取的步长,以下实例在索引 1 到索引 4 的位置并设置为步长为 2(间隔一个位置)来截取字符串:
四、Python 转义字符
有些特殊字符没有办法用普通字符表示,需要进行转义。python用反斜杠()转义字符。如下表:
转义字符 | 转义字符 |
\(在行尾时) | 续行符 |
\\ | 反斜杠符号 |
\’ | 单引号 |
\" | 双引号 |
\n | 换行 |
\v | 纵向制表符 |
\t | 横向制表符 |
\r | 回车 |
五、Python 三引号
Python 中三引号可以将复杂的字符串进行赋值。
Python 三引号允许一个字符串跨多行,字符串中可以包含换行符、制表符以及其他特殊字符。
三引号的语法是一对连续的单引号或者双引号(通常都是成对的用)。
>>> hi = '''hi
there'''
>>> hi # repr()
'hi\nthere'
>>> print(hi) # str()
hi
there
三引号让程序员从引号和特殊字符串的泥潭里面解脱出来,自始至终保持一小块字符串的格式是所谓的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=Back
ONCLICK="window.history.back()"></FORM>
</BODY></HTML>
'''
cursor.execute('''
CREATE TABLE users (
login VARCHAR(8),
uid INTEGER,
prid INTEGER)
''')
六、Python字符串内置方法
https://www.runoob.com/python3/python3-string.html Python 的字符串常用内建函数如下:
1、判断类型-9
序号 | 方法 | 描述 |
1 | isalnum() | 方法检测字符串是否由字母和数字组成。如果字符串至少有一个字符并且所有字符都是字母或数字则返 回 True,否则返回 False. |
2 | isalpha() | 方法检测字符串是否只由字母或文字组成。如果字符串至少有一个字符并且所有字符都是字母则返回 True, 否则返回 False. |
3 | isdigit() | 方法检测字符串是否只由数字组成。如果字符串只包含数字则返回 True 否则返回 False |
4 | isnumeric() | 方法检测字符串是否只由数字组成,数字可以是: Unicode 数字,全角数字(双字节),罗马数字,汉字数字。指数类似 ² 与分数类似 ½ 也属于数字。如果字符串中只包含数字字符,则返回 True,否则返回 False |
5 | isdecimal() | 检查字符串是否只包含十进制字符,如果是返回 true,否则返回 false。 |
6 | isspace() | 方法检测字符串是否只由空白字符组成。如果字符串中只包含空白,则返回 True,否则返回 False. |
7 | islower() | 方法检测字符串是否由小写字母组成。如果字符串中包含至少一个区分大小写的字符,并且所有这些(区分大小写的)字符都是小写,则返回 True,否则返回 False |
8 | isupper() | 方法检测字符串中所有的字母是否都为大写。如果字符串中包含至少一个区分大小写的字符,并且所有这些(区分大小写的)字符都是大写,则返回 True,否则返回 False |
9 | istitle() | 方法检测字符串中所有的单词拼写首字母是否为大写,且其他字母为小写。如果字符串是标题化的(见 title())则返回 True,否则返回 False |
2、查找和替换-7
序号 | 方法 | 描述 |
1 | endswith(suffix[, start[, end]]) | 方法用于判断字符串是否以指定后缀结尾,如果以指定后缀结尾返回 True,否则返回 False。可选参数 “start” 与 “end” 为检索字符串的开始与结束位置。 |
2 | startswith(substr, beg=0,end=len(string)) | 检查字符串是否是以指定子字符串 substr 开头,是则返回 True,否则返回 False。如果beg 和 end 指定值,则在指定范围内检查。 |
3 | find(str, beg=0, end=len(string)) | 检测 str 是否包含在字符串中,如果指定范围 beg 和 end ,则检查是否包含在指定范围内,如果包含返回开始的索引值,否则返回-1 |
4 | rfind(str, beg=0,end=len(string)) | 类似于 find()函数,不过是从右边开始查找. |
5 | index(str, beg=0, end=len(string)) | 跟find()方法一样,只不过如果str不在字符串中会报一个异常. |
6 | rindex( str, beg=0, end=len(string)) | 类似于 index(),不过是从右边开始. |
7 | replace(old, new [, max]) | 把 将字符串中的 str1 替换成 str2,如果 max 指定,则替换不超过 max 次。 |
3、大小写转换-5
序号 | 方法 | 描述 |
1 | capitalize() | 将字符串的第一个字符转换为大写 |
2 | title() | 返回"标题化"的字符串,就是说所有单词都是以大写开始,其余字母均为小写(见 istitle()) |
3 | upper() | 转换字符串中的小写字母为大写 |
4 | lower() | 转换字符串中所有大写字符为小写. |
5 | swapcase() | 将字符串中大写转换为小写,小写转换为大写 |
4、文本对齐-3
序号 | 方法 | 描述 |
1 | rjust(width,[, fillchar]) | 返回一个原字符串右对齐,并使用fillchar(默认空格)填充至长度 width 的新字符串 |
2 | ljust(width[, fillchar]) | 返回一个原字符串左对齐,并使用 fillchar 填充至长度 width 的新字符串,fillchar 默认为空格。 |
3 | center(width, fillchar) | 返回一个指定的宽度 width 居中的字符串,fillchar 为填充的字符,默认为空格。 |
5、去除空白字符-3
序号 | 方法 | 描述 |
1 | strip([chars]) | 方法用于移除字符串头尾指定的字符(默认为空格)或字符序列。注意:该方法只能删除开头或是结尾的字符,不能删除中间部分的字符。 |
2 | lstrip() | 截掉字符串左边的空格或指定字符。 |
3 | rstrip() | 删除字符串字符串末尾的空格. |
6、拆分和连接-3
序号 | 方法 | 描述 |
1 | split(str="", num=string.count(str)) | num=string.count(str)) 以 str 为分隔符截取字符串,如果 num 有指定值,则仅截取 num+1 个子字符串 |
2 | splitlines([keepends]) | 按照行(’\r’, ‘\r\n’, \n’)分隔,返回一个包含各行作为元素的列表,如果参数 keepends 为 False,不包含换行符,如果为 True,则保留换行符。 |
3 | join(seq) | 以指定字符串作为分隔符,将 seq 中所有的元素(的字符串表示)合并为一个新的字符串 |
7、其它-10
序号 | 方法 | 描述 |
1 | count(str, beg= 0,end=len(string)) | 返回 str 在 string 里面出现的次数,如果 beg 或者 end 指定则返回指定范围内 str 出现的次数 |
2 | bytes.decode(encoding=“utf-8”, errors=“strict”) | Python3 中没有 decode 方法,但我们可以使用 bytes 对象的 decode() 方法来解码给定的 bytes 对象,这个 bytes 对象可以由 str.encode() 来编码返回。 |
3 | encode(encoding=‘UTF-8’,errors=‘strict’) | 以 encoding 指定的编码格式编码字符串,如果出错默认报一个ValueError 的异常,除非 errors 指定的是’ignore’或者’replace’ |
4 | expandtabs(tabsize=8) | 把字符串 string 中的 tab 符号转为空格,tab 符号默认的空格数是 8 。 |
5 | len(string) | 返回字符串长度 |
6 | zfill (width) | 返回长度为 width 的字符串,原字符串右对齐,前面填充0 |
7 | maketrans() | 创建字符映射的转换表,对于接受两个参数的最简单的调用方式,第一个参数是字符串,表示需要转换的字符,第二个参数也是字符串表示转换的目标。 |
8 | max(str) | 返回字符串 str 中最大的字母。 |
9 | min(str) | 返回字符串 str 中最小的字母。 |
10 | translate(table, deletechars="") | 根据 str 给出的表(包含 256 个字符)转换 string 的字符, 要过滤掉的字符放到 deletechars 参数中 |
七、str.format()格式化方法
前面说过%百分符格式化方法。Python官方逐步在推广str.format()方法的格式化。
fromat()方法是字符串的内置方法,其基本语法如下:
参数列表:[[fill]align][sign][#][0][width][,][.precision][type]
fill 空白处填充的字符
align 对齐方式(需配合width使用)
>右对齐(默认),<左对齐, ^居中对齐
= 内容右对齐,将符号放置在填充字符的左侧,且只对数字类型有效。 即使:符号+填充物+数字
sign 有无符号数字
+,正号加正,负号加负;-,正号不变,负号加负;空格 ,正号空格,负号加负;
# 对于二、八、十六进制,如果加上#,会显示 0b/0o/0x,否则不显示
width 格式化位所占宽度
,为数字添加分隔符,如:1,000,000
.precision 小数位保留精度
type 格式化类型
传入“字符串类型”的参数:
s,格式化字符串类型数据
空白,未指定类型,则默认是None,同s
传入“整数类型”的参数:
b,将10进制整数自动转换成2进制表示然后格式化
c,将10进制整数自动转换为其对应的unicode字符
d,十进制整数
o,将10进制整数自动转换成8进制表示然后格式化;
x,将10进制整数自动转换成16进制表示然后格式化(小写x)
X,将10进制整数自动转换成16进制表示然后格式化(大写X)
传入“浮点型或小数类型”的参数:
e, 转换为科学计数法(小写e)表示,然后格式化;
E, 转换为科学计数法(大写E)表示,然后格式化;
f, 转换为浮点型(默认小数点后保留6位)表示,然后格式化;
F, 转换为浮点型(默认小数点后保留6位)表示,然后格式化;
g, 自动在e和f中切换
G, 自动在E和F中切换
%,显示百分比(默认显示小数点后6位)
去除复杂的参数,简单的format格式化方法基本有两类:
1、位置参数 {0}、{1}、{2},引用必须按顺序。例如:
tpl = "i am {0}, age {1}, really {0}".format("seven", 18)
2、关键字参数 {name}、{age}、{gender},引用时必须以键值对的方式,可以随意调整顺序。
tpl = "i am {name}, age {age}, really {name}".format(name="seven", age=18)
tpl = "i am {}, age {}, {}".format("seven", 18, 'alex')
tpl = "i am {}, age {}, {}".format(*["seven", 18, 'alex'])
tpl = "i am {0}, age {1}, really {0}".format("seven", 18)
tpl = "i am {0}, age {1}, really {0}".format(*["seven", 18])
tpl = "i am {name}, age {age}, really {name}".format(name="seven", age=18)
tpl = "i am {name}, age {age}, really {name}".format(**{"name": "seven", "age": 18})
tpl = "i am {0[0]}, age {0[1]}, really {0[2]}".format([1, 2, 3], [11, 22, 33])
tpl = "i am {:s}, age {:d}, money {:f}".format("seven", 18, 88888.1)
tpl = "i am {:s}, age {:d}".format(*["seven", 18])
tpl = "i am {name:s}, age {age:d}".format(name="seven", age=18)
tpl = "i am {name:s}, age {age:d}".format(**{"name": "seven", "age": 18})
tpl = "numbers: {:b},{:o},{:d},{:x},{:X}, {:%}".format(15, 15, 15, 15, 15, 15.87623, 2)
tpl = "numbers: {:b},{:o},{:d},{:x},{:X}, {:%}".format(15, 15, 15, 15, 15, 15.87623, 2)
tpl = "numbers: {0:b},{0:o},{0:d},{0:x},{0:X}, {0:%}".format(15)
tpl = "numbers: {num:b},{num:o},{num:d},{num:x},{num:X}, {num:%}".format(num=15)
更多的用法,请参考官方文档https://docs.python.org/3/library/string.html
八、字符串颜色控制
有时候我们需要对有用的信息设置不同颜色来达到强调、突出、美观的效果,在命令行中,颜色是用转义序列控制的,转义序列是以ESC开头,在代码中用\033表示(ESC的ASCII码用十进制表示就是27,等于用八进制表示的33,\0表示八进制)。注意:颜色控制只在终端界面中有效。
格式:\033[显示方式;前景色;背景色m正文\033[0m
print('\033[1;31;43m 前景色:红色;背景色:黄色\033[0m')
前景色 背景色 颜色
30 40 黑色
31 41 红色
32 42 绿色
33 43 黃色
34 44 蓝色
35 45 紫红色
36 46 青蓝色
37 47 白色
显示方式:
显示方式 意义
0 终端默认设置
1 高亮显示
4 使用下划线
5 闪烁
7 反白显示
8 不可见
例子:
\033[1;31;40m 1-高亮显示 31-前景色红色 40-背景色黑色
\033[0m 采用终端默认设置,也就是取消颜色设置
比如下面的代码:
import time
# 初始化
from colorama import init
init()
print('\033[1;31m')
print('登录信息'.center(46, "*"), "\033[0m")
print('\033[34m*HOST:\t', "192.168.1.10")
print('*PORT:\t', "80")
print('*User:\t', "jack")
print('*TIME:\t', time.strftime("%Y-%m-%d %H:%M:%S", time.localtime()))
print('\033[1;31m*' * 50, '\033[0m')
print("\033[32m欢迎登录!\033[0m")
九、字符编码
计算机只能处理数字0、1,如果要处理文本,就必须先把文本转换为数字0、1,这种转换方式就称为字符编码。
对于我们而言,你只需要简单记住下面几种编码就好:
• ASCII编码:早期专门为英语语系编码,只有255个字符,每个字符需要8位也就是1个字节。不兼容汉字。
• Unicode编码:又称万国码,国际组织制定的可以容纳世界上所有文字和符号的字符编码方案。用2个字节来表示汉字。
• UTF-8编码:为了节省字节数,在Unicode的基础上进行优化的编码。用1个字节表示英文字符,3个字符表示汉字。天生兼容ASCII编码,所以最为流行。
• GB2312:我国早期自己制定的中文编码,世界范围内不通用。
• GBK: 全称《汉字内码扩展规范》,向下与GB2312兼容,向上支持ISO10646.1国际标准,是前者向后者过渡过程中的一个承上启下的产物。windows中文版的汉字编码用的就是GBK。也非世界范围通用的编码
• 其它编码:非以上类型者的统称。属于能不用就不要碰的编码。
最后再强调一次,Python3在运行时全部使用Unicode编码! 另外有这么几条规则,你要记住:
• 操作系统运行时,在内存中,统一使用的都是Unicode编码,当需要将数据保存到硬盘或者网络传输的时候,就转换为UTF-8编码,进行保存和传输。
• 用文本编辑器的时候,从文件系统或者说硬盘上读取的UTF-8编码字符被转换为Unicode字符到内存里,供程序或者操作系统使用。编辑完成后,保存的时候再把Unicode转换为UTF-8保存到文件。
• 浏览网页的时候,服务器会把动态生成的Unicode内容转换为UTF-8传输到客户的浏览器。
这就是为什么我们一会说Unicode,一会又用utf-8的原因。
另外,一定要区分代码自己本身的编码和程序要处理的数据的编码!没有特殊要求的情况,请使用utf-8编码。确保文本编辑器使用的是UTF-8 without BOM编码。