一、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开始的,最大范围是字符串开头

Python 1-06 字符串_Python


• [头下标:尾下标] 获取的子字符串包含头下标的字符,但不包含尾下标的字符。

比如:

>>> s = 'abcdef'
>>> s[1:5]
'bcde'

Python 列表截取可以接收第三个参数,参数作用是截取的步长,以下实例在索引 1 到索引 4 的位置并设置为步长为 2(间隔一个位置)来截取字符串:

Python 1-06 字符串_python_02

四、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()方法的格式化。

Python 1-06 字符串_python_03

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编码。