字符串
1、字符串是python提供的容器型数据类型(序列),不可变,有序。
---不可变:不支持增删改
---有序:支持下标操作
2、python字符串是单引号或者双引号内的字符集
3、字符:python中有字符的概念,没有字符数据类型。
----普通字符:数字、字母、符号etc
----转义字符:\n、\、\t etc
----阻止转义:在字符串的最前面加r/R,能够阻止字符串中所有转义字符转义
print('============')
str1 = R'\thow\nare\nyou\"'
print(str1)
输出结果为
\thow\nare\nyou\"
4、编码字符:在字符串中用‘\u四位十六进制数’来表示一个字符
5、字符编码:
----计算机本身只有直接存储数字的能力(存数字的二进制的补码),为了能够存储数字以外的符号,
----开发人员给每个字符对应一个固定的数字用来对字符进行存储。每个字符对应的固定的数字就是字符的编码值。
----每个字符和数字的一一对应关系就是字符编码表,常见的编码表有: ASCII码表、Unicode编码表
ASCII码表采用一个字节对字符进行编码:0-127
Unicode编码表采用2个字节对字符进行编码, 包含了ASCII码
chr函数: chr(编码值) - 获取编码值对应的字符
ord函数: ord(字符) - 获取指定字符对应的编码
字符串操作
获取单个字符
语法: 字符串[下标] - 获取指定下标对应的字符
说明: 字符串 - 结果是字符串的表达式(字符串值、字符串变量、运算结果是字符串)
[] - 固定写法
下标 - 又叫索引,值是整数;字符串确定后,字符串中的没有字符都有一个确定的下标/索引表示这个字符在字符串中的位置。
python中下标有两种,位置从往后是 0 ~ 字符串长度-1; 位置从后往前是 -1 ~ -字符串长度
注意: 获取单个字符的时候下标不能越界
获取部分字符(即字符串切片)
语法: 字符串[开始下标:结束下标:步长] - 从开始下标开始获取,每次增加步长取下一个值;取到结束下标前为止(结束下标对应的值取不到)
说明: 字符串 - 结果是字符串的表达式(字符串值、字符串变量、运算结果是字符串)
[]/: - 固定写法
开始下标 - 下标,整数。能取到对应的字符
结束下标 - 下标,整数。对应的字符取不到
步长 - 整数。如果步长是正数,从前往后取;如果步长是负数,从后往前取
注意: 1.字符串切片的结果都是字符串
2.如果步长是正数,那么开始下标对应字符要在结束下标对应的字符的前面,才能取到值;
如果步长是负数,那么开始下标对应的字符要在结束下标对应的字符的后面,才能取到值
注意:切片的时候下标可以越界
print('====================')
str3 = 'abc+123'
print(str3[0:3:2]) # 'abc' 'ac'
print(str3[2:-2:1]) # 'c+1'
print('结果:', str3[2:-2:-1]) # ''
print(str3[0:-1:1]) # abc+12
print(str3[-1:2:-1]) # 321+
print(str3[-1:1:-2]) # 31c
print(str3[-100:100:1]) # abc+123
获取部分字符的简写
----省略步长 - 步长为1
语法: 字符串[开始下标:结束下标] <===> 符串[开始下标:结束下标:1]
----省略开始下标 - 步长为正从字符串开头往后获取;步长为负从字符串最后往前获取
语法: 字符串[:结束下标:步长] 、字符串[:结束下标]
----省略结束下标 - 步长为正,取到字符串最后一个字符为止; 步长为负取到第一个字符为止
语法: 字符串[开始下标::步长]、 字符串[开始下标:]
遍历字符串 - 将字符串中的字符一个一个的取出来
"""
for 变量 in 字符串:
循环体
"""
直接遍历, 变量取到的就是字符
str4 = 'hello world'
for char in str4:
print(char)
print('=====================')
# 简介遍历, 通过遍历下标遍历字符
for index in range(11):
print(str4[index])
字符串相关操作
1.字符串的运算:
- 数学运算符: +, *
字符串1+字符串2: 两个字符串相加 -> 将两个字符串拼接产生一个新的字符串
str1 = 'abc' + 'hello'
print(str1) # abchello
字符串*正整数/ 正整数*字符串: 字符串重复指定次数产生一个新的字符串
str2 = 'abc' * 3
str2 = 3 * 'abc'
print(str2)
- 比较运算: >, <, >=, <=, ==, !=
针对两个字符串进行比较
字符串比较大小: 按位置从前往后一对一对的比较,找出第一对不相等的字符,看它们的编码值谁大,那个字符串就大
应用:
判断一个字符是否是小写字母: 'a'<=char<='z'
判断一个字符是否是大写字母: 'A'<=char<='Z'
判断一个字符是否是字母: 'a'<=char<='z' or 'A'<=char<='Z'
判断一个字符是否是数字字符: '0'<=char<='9'
判断一个字符是否是中文(4e00-9fa5): '\ue400'<=char<='\u9fa5', '一'<=char<='龥'
- in 和 not in
字符串1 in 字符串2 - 判断字符串2中是否包含字符串1
print('abc' in 'a123abc') # True
print('abc' in '123ab1c') # False
print('A' in 'hell A') # True
print('A' not in 'hello A') # False
3.len
len(字符串) - 获取字符串长度(字符串中字符的个数)
print(len('abc'))
print(len('\tabc')) # 4
str6 = ' abc'
print(len(str6)) # 7
print(len('\u4e00abc')) # 4
for index in range(len('husjssas')):
print(index)
4.str
str(数据) - 将其他类型数据转换成字符串
所有类型的数据都可以转换成字符串; 转换的时候直接数据的外面加引号
print(str(100)) # '100'
print(str(12.5)) # '12.5'
print(str(True)) # 'True'
5.格式字符串: 在字符串中用格式占位符代替字符串中变化的部分,然后再使用数据对变化的部分进行赋值
语法: 包含格式占位符的字符串 % (数据1,数据2,...)
说明: 数据的个数和类型要和前面字符串中格式占位的个数和类型保持一致
格式占位符: %s - 字符串
%d - 整数
%.Nf - 浮点数(N控制小数后小数的位数)
%c - 字符、字符对应的编码值
name = input('姓名:')
age = int(input('请输入年龄:'))
money = 3.5
# '我是XX,今年XX岁, 薪资:xxk'
message = '我是%s, 今年%d岁, 薪资:%.1fk 等级:%c' % (name, age, money, 66)
# message = '我是'+name+', 今年' + str(age) + '岁'
print(message)
字符串的对象方法
1、字符串.函数名()
2、设置对齐方式:
字符串.center(width,fillchar) - 让字符串在新字符串居中,width控制新子串的宽度,fillchar是自定义的填充字符
字符串.rjust(width,fillchar)
字符串.ljust(width,fillchar)
字符串.zfill(width) <==> 字符串.rjust(width,'0')
str1 = 'abc'
print(str1,ceter(7,'+'))
print(str.ljust(7,'*'))
print(str1.rjust(7.'='))
num = 15
print(str(num).rjust(3,'0'))
print(str(num).zfill(3))
结果如下显示
++abc++
abc****
====abc
015
015