1,什么是字符串(str)
1)字符串
字符串是容器型数据类型(序列);以单引号或者双引号作为容器的标志,引号中所有的内容都输入字符串的元素
'abc' -> 元素分别是‘a','b','c', 3个元素
’a,b,c' -> 分别是‘a', ',', 'b', ',' 'c' 5个元素
特点: 不可变,有序(支持下标操作)
2)字符串的元素
字符串中元素又叫字符(注意:python中有字符的概念,但是没有字符类型;长度是1的字符串就可以看成字符)
a.普通字符: 字母,数字,各国的文字符号等(可以写在引号中的符号)
’abc', 'abc123','+-%....'
b.转义字符:字符串中在一些特定的符号前加\来表示特殊功能和意义
' - 表示一个单引号
" - 表示一个双引号
\n - 表示换行
\ - 表示一个
\t - 相当于一个 tab 键(制表符)
c.\u 4位16进制数 - 将4位16进制数对应的编码值转换成字符串
1).字符编码
计算机只有直接存储数字的能力,不能直接存储字符;当需要计算机存储字符的敌后,
实质存的是字符对应的固定的数字,这个数字就是字符在计算机中的编码
每一个字符和数字的对应关系叫编码表
2)ASCII编码表和Unicode编码表.
ASCII码表是由美国国家制定的专门针对美国符号进行编码的,里面只包含一些特殊符号,字母和数字(不包含中文,日语,韩语
python 采用的是Unicode编码表 :unciode 编码表是对ascii表的扩展 ,包含了世界上所有国家的语言的符号
中文编码起止 0x4e00--0x9fa5
3).字符编码相关方法
chr(编码值) - 将编码值转换成字符
ord(字符) - 将字符转换成编码
num = 0
for x in range(0x4e00, 0x9fa5):
num += 1
print(chr(x), end=' ')
if num % 35 == 0:
print()
print()
.获取字符 - 和获取列表元素一样
str1 = 'hello word!'
1)获取单个字符
print(str1[0]) # h
- 字符串切片
)遍历
for char in 'abc':
print(char)
统计一份字符串中小写字母的个数
str2 = 'how Are You!Im Fine ,THANK YOU'
count = 0
for char in str2:
if 97 <= ord(char) <= 122:
count += 1
print(count)
2.字符串操作
1)+ 和 *
字符串1 + 字符串2 -> 将字符串1和字符串2拼接在一起产生一个新的字符串
字符串 * N/N * 字符串 -> 字符串重复N次产生一个新的字符串
2) == !=
print('abc' == 'abc') #True
print('abc' == 'bca') #False
3)> < >= <=
只能两个字符串比较大小,从前往后找到第一组不相等的字符,比较他们编码值的大小,谁的编码值大哪个字符串就大
print('abc' > 'bc') #False
'0' <= char <= '9' -- 判断是否是数字字符
'a' <= char <= 'z'
'A' <= char <= 'Z'
4)in / not in
字符串1 in 字符串 -> 判断字符串2中是否包含字符串1(判断字符串1是否是字符串2)
5) len max min sum ,sorted str
字符串转换:所有的数据都可以转换成字符,转换的时候是将数据放在引号中
注意:转义字符串和编码字符的长度都是1
sorted 返回的是列表
6)r 语法
在字符串的最前面加r或R,就可以阻止字符串中所有的转义字符转义
str1 = '\thow\nare'you!\u4e00'
print(str1)
str1 = R'\thow\nare'you!\u4e00'
print(str1)
7)格式字符串
在字符串中用格式占位符表示字符串中不确定的部分
语法: 包含格式占位符的字符 %(数据1, 数据2 ,...) - () 中数据的个数和类型要和前面格式占位符一一对应
b.格式占位符
%s - 字符串
%d - 整数
%,Nf - 浮点数,N控制小数点后小数的位数
%c - 字符(可以将数字转换成字符)
注意:1. 所有数据都可以使用%s作为占位符,2,所有数据都可以使用%s来接受
name = input('请输入姓名:')
age = int(input('请输入年龄:'))
gender = input('请输入性别:')
message2 = '%s今年%d岁,性别:%s! '%(name, age, gender)
print(message)
1.对齐方式
字符串.center(宽度,填充字符 = ' ')-- 居中
字符串.ljust(宽度,填充字符 = ' ')-- 左对齐
字符串.rjust(宽度,填充字符 = ' ')-- 右对齐
字符串.zfill(宽度) == 字符串.rjust(宽度,0)
str1 = 'abc'
print(str1,center(9, '+')) #居中
- 统计字符的个数
字符串1.count(字符串2) - 统计字符串1中字符串2出现的次数
str1 = 'how are you!'I'm fine'
3获取字符串下标
# 字符串1.count(字符串2) - 统计字符串1中字符串2出现的次数
str1 = 'how are you! Im fine, thank you! and you?'
print(str1.count('you')) # 3
print(str1.count('h')) # 2
print(str1.count('you', 0, 12)) # 在下标是[0, 12)范围内统计'you'的个数
# 3.获取子串下标
print(str1.find('you')) # 8
print(str1.index('you')) # 8
print(str1.find('you1')) # -1
# print(str1.index('you1')) # ValueError: substring not found
4.join方法
字符串.join(序列) - 将序列中的元素用字符串连接产生一个新的字符串
要求序列中的元素必须是字符串,如果是
new_str1 = '+'.join('123')
print(new_str1) # '1+2+3'
new_str1 = 'and'.join(['小明', '小花', '小红'])
print(new_str1) # 小明and小花and小红
new_str1 = '-'.join({'name': '小明', 'age': 18,'gender': 'boy'})
print(new_str1) # name-age-gender
5.替换
字符串1.replace(字符串2,字符串3) - 将字符串1中所有的字符串2都替换成字符串3
字符串1.replace(字符串2,字符串3,N) - 将字符串1中前N个字符串2都替换成字符串3
str1 = 'how are you! Im fine, thank you! and you?'
new_str1 = str1.replace('you', 'YOU') # how are YOU! Im fine, thank YOU! and YOU?
print(new_str1)
new_str1 = str1.replace('you', 'me', 2) # how are me! Im fine, thank me! and you?
print(new_str1)
6.字符串切割
字符串1.split(字符串2) - 将字符串2作为切割点切割字符串1,返回一个列表
str1 = 'how are you! Im fine, thank you! and you?'
str_list = str1.split(' ')
print(str_list) # ['how', 'are', 'you!', 'Im', 'fine,', 'thank', 'you!', 'and', 'you?']
str_list = str1.split('!')
print(str_list) # ['how are you', ' Im fine, thank you', ' and you?']