1.字符串表达式
引号引起来的单引号、双引号、三引号(三个三引号或双引号);
str1='hello world'
str2="hello world"
str3="""hello world"""
str4='''hello world'''
2.type结果
字符串用type函数检测的结果为str
x="hello world"
print(type(x))#<class 'str'>
3.转义字符串
使用反斜杠\对字符进行转义,如 \r 回车 \n 换行 \t 缩进 \\ 表示 \
x="hello\nworld"
print(x)
"""
打印
hello
world
"""
x="hello\tworld"
print(x)
"""
打印
hello world
"""
x="hello\\world"
print(x)
"""
打印
hello\world
"""
4.不转义
字符串前加r表示原始字符串:所见即所得,不转义;
x=r'c:\window\user\data'
print(x)
5.字符串运算
-
字符串连接:+;
-
相邻的两个或多个字符串字面值 (引号标注的字符)会自动合并
x='Py' 'thon' print(x)#Python print("------------------") a='hello' b='world' print(a+b)#helloworld
-
字符串多次重复, 如 :
x=3*'ab' print(x)#ababab
-
可以把字符串看成数组,通过下标访问字符,支持负数:
x='abc'[1] print(x)#b
-
支持通过下标截取子字符串,第一个参数省略表示0,第二个参数省略表示到最后:
x='hello world'[0:5] print(x)#hello y='hello world'[6:] print(y)#world
6.f-string
f-string 是 python3.6 之后版本添加的,称之为字面量格式化字符串,是新的格式化字符串的语法(旧的字符串格式化自行了解)。
之前我们习惯用百分号 (%):
实例
name = 'World'
print('Hello %s' % name)#Hello World
f-string 格式化字符串以 f 开头,后面跟着字符串,字符串中的表达式用大括号 {} 包起来,它会将变量或表达式计算后的值替换进去
用了这种方式明显更简单了,不用再去判断使用 %s,还是 %d。
x = 1
print(f'{x+1}') #2
x = 1
print(f'{x+1=}') #x+1=2
7.字符串的常用函数API
Python 的字符串常用内建函数如下:
序号 | 方法及描述 |
---|---|
1 | capitalize()将字符串的第一个字符转换为大写 |
2 | center(width, fillchar)返回一个指定的宽度 width 居中的字符串,fillchar 为填充的字符,默认为空格。 |
3 | count(str, beg= 0,end=len(string))返回 str 在 string 里面出现的次数,如果 beg 或者 end 指定则返回指定范围内 str 出现的次数 |
4 | endswith(suffix, beg=0, end=len(string))检查字符串是否以 suffix 结束,如果 beg 或者 end 指定则检查指定的范围内是否以 suffix 结束,如果是,返回 True,否则返回 False。 |
5 | expandtabs(tabsize=8)把字符串 string 中的 \t 符号转为空格,tab 符号默认的空格数是 8 。 |
6 | find(str, beg=0, end=len(string))检测 str 是否包含在字符串中,如果指定范围 beg 和 end ,则检查是否包含在指定范围内,如果包含返回开始的索引值,否则返回-1 |
7 | index(str, beg=0, end=len(string))跟find()方法一样,只不过如果str不在字符串中会报一个异常。 |
8 | isalnum()非空字符串 中没有符号 就返回True |
9 | isalpha()非空字符串 中没有符号和数字 就返回True |
10 | isdigit()如果字符串只包含数字则返回 True 否则返回 False.. |
11 | islower() 用于检测字符串中的所有字符是否都是小写字母,字符都是小写,则返回 True,否则返回 False |
12 | isnumeric()如果字符串中只包含数字字符,则返回 True,否则返回 False |
13 | isspace()如果字符串中只包含空白,则返回 True,否则返回 False. |
14 | istitle()如果字符串是标题化的(见 title())则返回 True,否则返回 False |
15 | isupper()用于检测字符串中的所有字符是否都是大写字母,并且都是大写,则返回 True,否则返回 False |
16 | join(seq)以指定字符串作为分隔符,将 seq 中所有的元素(的字符串表示)合并为一个新的字符串 |
17 | len(string)返回字符串长度 |
18 | ljust(width, fillchar])返回一个原字符串左对齐,并使用 fillchar 填充至长度 width 的新字符串,fillchar 默认为空格。 |
19 | lower()转换字符串中所有大写字符为小写. |
20 | lstrip()截掉字符串左边的空格,\t,\r,\n或指定字符。 |
21 | maketrans()创建字符映射的转换表,对于接受两个参数的最简单的调用方式,第一个参数是字符串,表示需要转换的字符,第二个参数也是字符串表示转换的目标。 |
22 | max(str)返回字符串 str 中最大的字母。 |
23 | min(str)返回字符串 str 中最小的字母。 |
24 | replace(old, new , max)把 将字符串中的 old 替换成 new,如果 max 指定,则替换不超过 max 次。 |
25 | rfind(str, beg=0,end=len(string))类似于 find()函数,不过是从右边开始查找. |
26 | rindex( str, beg=0, end=len(string))类似于 index(),不过是从右边开始. |
27 | rjust(width, fillchar)返回一个原字符串右对齐,并使用fillchar(默认空格)填充至长度 width 的新字符串 |
38 | rstrip()删除字符串末尾的空格\t,\r,\n或指定字符。 |
29 | split(sep="", maxsplit=string.count(str))以 sep为分隔符截取字符串,如果 maxsplit有指定值,则仅截取 maxsplit+1 个子字符串 |
30 | splitlines(keepends)按照行('\r', '\r\n', \n')分隔,返回一个包含各行作为元素的列表,如果参数 keepends 为 False,不包含换行符,如果为 True,则保留换行符。 |
31 | startswith(substr, beg=0,end=len(string))检查字符串是否是以指定子字符串 substr 开头,是则返回 True,否则返回 False。如果beg 和 end 指定值,则在指定范围内检查。 |
32 | strip(chars)在字符串上执行 lstrip()和 rstrip() |
33 | swapcase()将字符串中大写转换为小写,小写转换为大写 |
34 | title()返回"标题化"的字符串,就是说所有单词都是以大写开始,其余字母均为小写 |
35 | upper()转换字符串中的小写字母为大写 |
36 | zfill (width) 在字符串左侧填充指定数量的零,确保整个字符串达到指定长度 |