1.什么是字符串(str):
- python自带的容器型数据类型(序列),不可变有序
- python中的字符串使用单引号或者双引号引起来的字符集;
引号里面的每个基本单元叫字符
2.字符
python中只有字符概念,没有字符类型
- 普通字符:数字、字母、中文、日语、普通符号等
str1 = "123 and 你好!!@#¥% ❀"
2.转义字符
在特定的字符前\来表示特殊功能或者特殊意义的字符
\n ->换行
\' \" ->单引号和双引号本身
\\ ->让一个\失去转义的功能
\t ->制表符
阻止转义:可以在字符串的最前面加r,R,能够阻止所有的转义字符转义
str1 = r'\thow\nare\nyou\"'
print(str1)
- 编码字符:在字符串\u四位的十六进制数 来表示一个字符
str1 = '123\u1234' # \u字符编码值的 16进制数
print(str1)
字符编码:
计算机本身只有直接存储数字的能力(二进制的补码),为了能够存储数字以外的符号
开发人员给每个字符对应一个固定的数字用来对字符进行存储,每个字符对应的固定
的数字就是字符的编码值。
每个字符和数字的一一对应关系就是字符编码表,常见的编码表有:ACSII码表、Unicode编码表
ACSII码表采用一个字节对字符进行编码:0-127
Unicode表采用2个字节对字符进行编码:包含了ASCII表
chr()函数:chr(编码值) - 获取编码值对应的字符
ord()函数:ord(字符) - 获取指定字符对应的编码
3.字符串的操作:查
- 获取单个字符
语法:字符串[下标] - 获取指定下标对应的字符
说明:字符串 - 结果是字符串的表达式(字符串值、支付穿变量、运算结果是字符串)
[] - 固定写法
下标 - 又叫索引,字符串确定后,字符串中的每一个字符都有确定的下标,表示这个字符在字符中的位置。
python中下标有两种,位置从后往前是0字符串长度-1;位置从后往前是-1字符串长度
注意:获取单个字符的时候下表不能越界
str1 = 'hello'
print(str1[0], str1[3])
print(str1[-1])
- 获取部分字符(字符串切片)
语法:字符串[开始下标:结束下标:步长] - 从开始下标开始获取,每次增加步长取下一个取到结束下标前为止
说明:字符串 - 结果是字符串的表达式
[]/: - 固定写法
开始下标 - 下标,整数。能取到对应的字符
结束下标 - 下标整数。对应的字符取不到
步长 - 整数。如果是正数,从前往后取;如果是负数,从后往前去取
注意:
1.字符串切片的结果都是字符串
2.如果步长是正数,开始下标对应的字符要在结束下标对应的前面,才能取到值;如果步长是负数,那么开始下标对应的字符要在结束下标对应的字符的后面,才能取到值
str2 = 'abc+123'
print(str2[0:3:1])
print(str2[2:-2:1]) # c + 1
print(str2[0:-1:1]) # 321+
print(str2[-1:1:-2]) # 31c
3.切片的实收下标可以越界
3.获取部分字符的简写
1.省略步长(步长为1的时候)
str2 = 'abc+123'
print(str2[0:3])
2.省略开始下标 - 步长为正从头往后获取;步长为负从后往前获取
语法:字符串[:结束下标:步长]、字符串[:结束下标]
str2 = 'abc+123'
print(str2[:3]) # abc
3.省略结束下标:步长为正,取到字符串最后一个为止;步长为负取到第一个为止
语法:字符串[开始下标::步长]、字符串[开始下标:]
str2 = 'abc+123'
print(str2[1:]) # bc+123
print(str2[1::-1]) # ba
print(str2[:]) # abc+123
print(str2[::-1]) # 321+cba
4.遍历字符串 - 将字符串中的字符一个一个的取出来
str2 = 'abc+123'
for x in str2:
print(x)
for x in range(len(str2)):
print(str2[x])
5.字符串的相关操作
1.字符串的运算
1.数学运算符:+,* -> +:字符串的拼接;*:字符串重复输出几次
str1 = 'abc' + 'hello' # 字符串的拼接
str1 = 'abc' * 3
2.比较运算符:>,<,>=,<=,==,!=(针对两个字符串的比较)
字符串比较大小,实际比的是字符串的编码值
应用:
判断一个数字是否是小写字母:'a' <= char <= 'z'
判断一个数字是否是大写字母:'A' <= char <= 'Z'
判断一个数字是否是字母:'a' <= char <= 'z' or 'A' <= char <= 'Z'
判断一个字符是否是中文(4e00 - 9fa5):'\ue400' <= char <= '\u9fa5'
3.赋值运算符:=,+=,*=
2.in 和 not in :判断一个字符串是否在另一个字符串中
3.len():len(字符串) -> 获取字符串中字符串的个数
4.str(数据):将其他类型数据转换成字符串(所有类型的数据都可以转成字符串)
5.格式字符串:在字符串中用格式占位符代替字符串中变化的部分,然后再使用数据对变化的部分进行赋值
语法:包涵格式占位符分字符串%(数据1,数据2)
说明:数据的个数和类型要和前面的字符串格式占位符的格式和类型保持一致
格式占位符:
%s - 字符串
%d - 整数
%.Nf - 浮点数 ->(N控制小数后小数的位数)
%c - 字符
name = input('请输入你的名字:')
age = int(input('请输入你的年龄:'))
money = float(input('请输入你的薪资(K):'))
print('我是%s,今年%d岁,每个月工资%.1fK' % (name, age, money))
6.字符串的对象方法
字符串.函数名()
1.字符串.capitalize() - 将字符串中的第一个字符转换成大写字母
str1 = 'abc'
print(str1.capitalize())
print('++++++++')
2.设置对齐方式
"""
字符串.center(width, fillchar) - 让字符串在新字符串中居中,width控制新字符串的宽度,fillchar设置填充字符
字符串.rjust(width, fillchar)
字符串.ljust(width, fillchar)
字符串.zfill(width) <==> 字符串.rjust(width, '0')
"""
str2 = 'abc'
print(str2.center(8, '+'))
print(str2.ljust(7, '/'))
print(str2.rjust(7, '='))
num = 15
print('学号:', str(num).rjust(3, '0'))
print('学号:', str(num).zfill(3))