字符串
字符串是使用' 或 "括起来的内容。
转义字符
转义字符 | 描述 |
---|---|
\\ | 反斜杠 \ |
\' | 单引号 ' |
\" | 双引号 " |
\n | 换行符 |
\ t | 制表符 |
阻止转义
可以通过在字符串前加r或R来阻止转义字符转义。
实例:
str1 = "I\'m YeHao ."
str2 = r"I'm YeHao ."
print(str1, str2)
output:
I'm YeHao . I'm YeHao .
Unicode编码
对于单个字符的编码,Python提供了ord()函数获取字符的整数表示,chr()函数把编码转换为对应的字符:
叶 = ord('叶')
浩 = ord('浩')
print(叶, 浩)
print(bin(叶), bin(浩))
print(oct(叶), oct(浩))
print(hex(叶), hex(浩))
print(chr(25105),chr(29233),chr(20320))
Output:
21494 28009
0b101001111110110 0b110110101101001
0o51766 0o66551
0x53f6 0x6d69
我 爱 你
字符串比较大小,从字符串的首字母开始依次往后比较每个字符的大小。
获取字符串中的字符
python的字符,实质上是一个有序的序列。
1. 获取字符串的长度
使用内置函数len().
count = len('Winter is coming .')
print(count)
Output:
18
2. 通过索引获取字符串中的某个字符
str1 = 'good good study\nday day up'
# 获取字符p
length = len(str1)
print(str1[length-1])
Output:
p
字符串倒序
str2 = "GodV"
print(str2[::-1])
Output:
VdoG
字符串运算符
下面实例中a = 'Happy' b = 'Python'
操作符 | 描述 | 实例 |
---|---|---|
+ | 字符串拼接 | a + b 输出结果:HappyPython |
* | 重复输出字符串 | a * 2输出结果:HappyHappy |
in | 如果字符串包含给定的字符则返回True | 'Ha' in a 输出结果:True |
not in | 如果字符串不包含给定的字符则返回True | 'M' not in a 输出结果:True |
字符串格式化
name = '马云'
age = 54
print('我叫%s,今年%d岁' % (name, age))
Output:
我叫马云,今年54岁
字符串格式化符号
符号 | 描述 |
---|---|
%s | 格式化字符串 |
%d | 格式化整数 |
%f | 格式化浮点数,可指定小数点后的精度,默认为6 |
%x或%X | 格式化十六进制数,X即大写 |
字符串操作内置函数
序号 | 方法 | 描述 |
---|---|---|
1 | capitalize() | 首字母大写 |
2 | center(width, fillchar) | 让一个字符串在指定的width内居中显示,fillchar为填充的字符,默认为空格 |
3 | ljust(width, fillchar) | 靠左对齐 |
4 | rjust(width, fillchar) | 靠右对齐 |
5 | bytes.decode(encoding="utf-8", errors="strict") | Python3 中没有 decode 方法,但我们可以使用 bytes 对象的 decode() 方法来解码给定的 bytes 对象,这个 bytes 对象可以由 str.encode() 来编码返回。 |
6 | encode(encoding='UTF-8',errors='strict') | 以 encoding 指定的编码格式编码字符串,如果出错默认报一个ValueError 的异常,除非 errors 指定的是'ignore'或者'replace' |
7 | endswith(suffix, beg=0, end=len(string)) | 检查字符串是否以 obj 结束,如果beg 或者 end 指定则检查指定的范围内是否以 obj 结束,如果是,返回 True,否则返回 False. |
8 | count(str, beg=0, end=len(string)) | 计算str在string出现的次数 |
9 | expandtabs(tabsize=8) | 把字符串 string 中的 tab 符号转为空格,tab 符号默认的空格数是 8 。 |
10 | find(str, beg=0 end=len(string)) | 检测 str 是否包含在字符串中,如果指定范围 beg 和 end ,则检查是否包含在指定范围内,如果包含返回开始的索引值,否则返回-1 |
11 | index(str, beg=0, end=len(string)) | 跟find()方法一样,只不过如果str不在字符串中会报一个异常. |
12 | isalnum() | 如果字符串至少有一个字符并且所有字符都是字母或数字则返 回 True,否则返回 False |
13 | isalpha() | 如果字符串至少有一个字符并且所有字符都是字母则返回 True, 否则返回 False |
14 | isdigit() | 如果字符串只包含数字则返回 True 否则返回 False.. |
15 | islower() | 如果字符串中包含至少一个区分大小写的字符,并且所有这些(区分大小写的)字符都是小写,则返回 True,否则返回 False |
16 | isnumeric() | 如果字符串中只包含数字字符,则返回 True,否则返回 False |
17 | isspace() | 如果字符串中只包含空白,则返回 True,否则返回 False. |
18 | istitle() | 如果字符串是标题化的(见 title())则返回 True,否则返回 False |
19 | isupper() | 如果字符串中包含至少一个区分大小写的字符,并且所有这些(区分大小写的)字符都是大写,则返回 True,否则返回 False |
20 | join(seq) | 以指定字符串作为分隔符,将 seq 中所有的元素(的字符串表示)合并为一个新的字符串 |
21 | len(string) | 返回字符串长度 |
22 | lower() | 转换字符串中所有大写字符为小写. |
23 | lstrip() | 截掉字符串左边的空格或指定字符。 |
24 | rstrip() | 删除字符串字符串末尾的空格. |
25 | strip([chars]) | 在字符串上执行 lstrip()和 rstrip() |
26 | maketrans() | 创建字符映射的转换表,对于接受两个参数的最简单的调用方式,第一个参数是字符串,表示需要转换的字符,第二个参数也是字符串表示转换的目标。 |
27 | max(str) | 返回字符串 str 中最大的字母。 |
28 | min(str) | 返回字符串 str 中最小的字母。 |
29 | replace(old, new [, max]) | 把 将字符串中的 str1 替换成 str2,如果 max 指定,则替换不超过 max 次。 |
30 | rfind(str, beg=0,end=len(string)) | 类似于 find()函数,不过是从右边开始查找. |
31 | swapcase() | 将字符串中大写转换为小写,小写转换为大写 |
32 | upper() | 转换字符串中的小写字母为大写 |
33 | isdecimal() | 检查字符串是否只包含十进制字符,如果是返回 true,否则返回 false。 |
34 | title() | 返回"标题化"的字符串,就是说所有单词都是以大写开始,其余字母均为小写(见 istitle()) |
isdigit()和isnumeric()的区别:
isdigit() | isnumeric() |
---|---|
True: Unicode数字,byte数字(单字节),全角数字(双字节),罗马数字 | True: Unicode数字,全角数字(双字节),罗马数字,汉字数字 |
False: 汉字数字 | False: 无 |
Error: 无 | byte数字(单字节) |