20210508Day08字符串
总结
1. 字符串
# 1.什么是字符串(str)
'''
字符串是容器性数据类型(序列),它将'',"",'''''',""""""作为容器标志里面每一个独立的符号都是字符串的一个元素
字符串不可变;字符串是有序的(支持下标操作)
字符串的元素:引号里面的每个符号都是字符串的元素,字符串的元素又叫字符.字符分为两种:普通字符,转义字符
'''
#1)空串
str1 = ''#空串:容器符号里什么都没有的字符串
empty1 = ''
empty2 = ""
empty3 = ''''''
empty4 = """"""
print(type(empty1),len(empty1))
print(type(empty2),len(empty2))
print(type(empty3),len(empty3))
print(type(empty4),len(empty4))
# <class 'str'> 0
# <class 'str'> 0
# <class 'str'> 0
# <class 'str'> 0
#2)字符串的容器标志
#''和""没有区别;,''''''和""""""没有区别
#''和""里面的内容不能通过直接按回车换行,只能通过转义字符换行;
#""""""和''''''里面的内容可以直接回车换行
#2.字符串的元素 - 字符
'''
字符分为普通字符和转义字符两种
1)普通字符 - 在字符串中表示符号本身的字符
2)转义字符 - 使用\和其他符号一起来表示特殊功能和意义的字符
\n -换行
\t -水平制表符(相当于tab键)
\' -表示一个普通的单引号
\" -表示一个普通的双引号
\\ -表示一个普通的反斜杠
3) 阻止转义 -让字符串中所有的转义字符功能消失(让一个字符串中的每一个符号都表示符号本身)
在字符串前加 r或者R
4) 转义字符-编码字符
'''
#3.编码值 -字符编码
#编码值 -计算机在存储符号的时候其实存的是这个符号对应的固定数字,这个数字就是符号对应的编码值
#编码表 -将字符和数字一一对应的值进行组合展示的值
'''
ASCII码表 - 总共由128个符号,只有美国常用符号,不包括中文
数字在字母的前面,大写字母(A自65起)在小写字母(a自97起)
大写字母和小写字母之间有间隙
Unicode编码表(Python) -Unicode编码表中包含Ascii码表
-包含了目前世界所有国家所有民族的所有语言符号(万国码);
中文编码范围:4e00~9fa5
chr(编码值) -获取编码值对应的字符
ord(字符) -获取指定字符的编码值(凡是需要字符的地方,都给长度是1的字符串)
hex(数据) -将其他进制的数据转换成16进制,\u的效果和hex()一样
'''
# 4.\u 16进制数 -16进制数的编码值对应的字符
2.计算机基础
#1.内存单位
# 位(bit)
# 1字节(byte) = 8位(bit) -程序申请内存的最小单位
# 1kb = 1024字节
# 1Mb = 1024Kb
# 1G = 1024G
# ...#计算机中数字常见进制有4中:2进制,8进制,10进制,16进制
#2.进制
#1)10进制
'''
基数: 0,1,2,3,4,5,6,7,8,9
进位: 逢10进1
位权: 你是第几位的数,你就是10**(N-1)次方
表示方式:直接写
'''
#2)2进制
'''
基数: 0,1
进位: 逢2进1
位权: 2**(N-1),110 = 1*2**0 + 1*2**1 + 0*2**3
表示方式:加前缀0b
'''
#3)8进制
'''
基数: 0,1,2,3,4,5,6,7
进位: 逢8进1
位权:
表示方式:加前缀0o/0O
'''
#4)16进制
'''
基数: 0,1,2,3,4,5,6,7,8,9,a,b,c,d,e,f(大小写无妨)
进位: 逢16进1
位权:
表示方式:加前缀0x/0X
'''
num = 0
for X in range(0x4e00,0x9fa6):
num += 1
print(chr(X), end=' ')
if num % 20 == 0:
print()
3.字符串的相关操作
#1.查 - 字符串获取字符和列表获取元素的语法一样
message = 'MerryChristmas'
print(message[2])
#一个空格是一个字符
#一个转义字符是一个字符,长度是1
str2 = '\tabc\u4fa9 123'
#其中的\u4fa9记作一个字符
print(str2[6])#1
#2.运算符
# 字符串1 + 字符串2 -将两个字符串拼接产生一个新字符串
# 字符串 * N - 将字符串重复N次产生一个新的字符串
#比较大小: >,<,>=,<(常用于判断字符属性)
'''
是否是数字字符:'0'<= char <= 9
是否是小写字母:'a' <= char <= 'z'
是否是大写字母:'A' <= char <= 'Z'
是否是字母:'a' <= char <= 'z' or 'A' <= char <= 'Z'
是否是中文
'''
#两个字符串比较大小比较的是第一对不相等的字符的编码值的大小
#练习:提取一个字符串中所有的数字字符
message = 'sh函数78sk--2o好'
new_message = ''
for X in message:
if 0x4e00 <= ord(X) <= 0x9fa5:
new_message += X
print(new_message)
#3. in 和not in
# 字符串1 in字符串2 判断字符串2 中是不是包含字符串1 (判断字符串1是否是字符串2的子串)
#4.len,str
#len()
#str(数据) -将数据转换成字符串.(任何类型的数据都可以转换成字符串,转换的时候直接在数据的打印值外打引号)
#容器型数据转换为字符串时,不会将原来容器里的元素作为新的元素放进字符串里,而是直接将原容器的打印值外直接加引号.
list1 = [1,2,3]
print(list1)
str(list1)
4.字符串相关方法
#1.join
#字符串.join(序列) -将序列中的元素使用指定字符串!链接!产生一个新的字符串.
# 序列中的元素必须是字符串
list1 = ['name', 23, True, '你好', '哈哈']
# 'name+你好+哈哈'
list2 = '+'.join([str(X) for X in list1 if type(X) == str])
print(list2)
#name+你好+哈哈
#2.切割split
#字符串.split(切割点)
#将字符串1中所有的字符串2作为切割点对字符串1进行切割,切割点在切割结束会消失
#返回的结果是以切割剩余的字符串为元素的列表
#如果切割点在最前或者最后,则会输出一个空串
#如果切割点之间是连续的,也会输出空串
#总之,切割出的元素个数总比切割点多一个
#字符串.split(切割点,N)
#意味切割N次
#3.replace
#字符串1.replace(字符串2,字符串3)
# -意为将字符串1中所有的字符串2替换成字符串3,直接生成新字符串,不影响原来的字符串
#字符串1.replace(字符串2,字符串3,N)
# -意为将字符串1中前N个字符串2替换成字符串3
练习
-
输入一个字符串,打印所有奇数位上的字符(下标是1,3,5,7…位上的字符)
例如: 输入**'abcd1234 ’ ** 输出**‘bd24’**
str1 = input('输入一个字符串') str2 = str1[1::2] print(str2)
-
输入用户名,判断用户名是否合法(用户名长度6~10位)
str1 = input('输入用户名') if 6 < len(str1) < 10: print('合法') else: print('不合法')
-
输入用户名,判断用户名是否合法(用户名中只能由数字和字母组成)
例如: ‘abc’ — 合法 ‘123’ — 合法 ‘abc123a’ — 合法
str1 = input('输入用户名') for X in str1: if '0' <= X <= '9' or 'a' <= X <= 'z' or 'A' <= X <= 'Z': continue else: print('不合法') break else: print('合法')
-
输入用户名,判断用户名是否合法(用户名必须包含且只能包含数字和字母,并且第一个字符必须是大写字母)
例如: ‘abc’ — 不合法 ‘123’ — 不合法 ‘abc123’ — 不合法 ‘Abc123ahs’ — 合法
str1 = input('输入用户名') list1 = [X for X in str1] while 'A' <= list1[0] <= 'Z': for X in str1: if '0' <= X <= '9' or 'a' <= X <= 'z' or 'A' <= X <= 'Z': continue else: print('不合法') break else: print('合法') break else: print('不合法')
-
输入一个字符串,将字符串中所有的数字字符取出来产生一个新的字符串
例如:输入**‘abc1shj23kls99+2kkk’** 输出:'123992’
str1 = input('输入字符串') str2 = ''.join([X for X in str1 if '0' <= X <= '9']) print(str2)
-
输入一个字符串,将字符串中所有的小写字母变成对应的大写字母输出 (用upper方法和自己写算法两种方式实现)
例如: 输入**‘a2h2klm12+’ ** 输出 'A2H2KLM12+'
str1 = 'a2h2klm12+' print(str1.upper()) #################################### str1 = 'a2h2klm12+' str2 = ''.join([chr(ord(X) - 32) if 'a' <= X <= 'z' else X for X in str1]) print(str2)
-
输入一个小于1000的数字,产生对应的学号
例如: 输入**‘23’,输出’py1901023’** 输入**‘9’, 输出’py1901009’** 输入**‘123’,输出’py1901123’**
num = input('请输入数字(0-999):') if len(num) == 1: print('py1901100',num,sep='') elif len(num) == 2: print('py190110',num,sep='') elif len(num) == 3: print('py19011',num,sep='')
-
输入一个字符串,统计字符串中非数字字母的字符的个数
例如: 输入**‘anc2+93-sj胡说’** 输出:4 输入**’===’** 输出:3
str1 = input('请输入:') count = 0 for X in str1: if '0' <= X <= '9' or 'a' <= X <= 'z' or 'A' <= X <= 'Z': count += 1 print(len(str1) - count)
-
输入字符串,将字符串的开头和结尾变成’+’,产生一个新的字符串
例如: 输入字符串**‘abc123’, 输出’+bc12+’**
str1 = input('请输入:') list1 = [X for X in str1] list1[0] = '+' list1[-1] = '+' str2 = ''.join([X for X in list1]) print(str2) ############################################# str1 = input('请输入:') str2 = '+' + str1[1:len(str1) - 1:] + '+' print(str2)
-
输入字符串,获取字符串的中间字符
例如: 输入**‘abc1234’** 输出:‘1’ 输入**‘abc123’** 输出**‘c1’**
str1 = input('请输入:')
if len(str1) % 2:
print(str1[len(str1) // 2])
else:
print(str1[len(str1) // 2 - 1],str1[len(str1) // 2])
- 写程序实现字符串函数find/index的功能(获取字符串1中字符串2第一次出现的位置)
例如: 字符串1为:how are you? Im fine, Thank you! , 字符串2为:you, 打印8
str1 = 'how are you? Im fine, Thank you!'
str2 = str1.split('you')
print(len(str2[0]))
- 获取两个字符串中公共的字符
例如: 字符串1为:abc123, 字符串2为: huak3 , 打印:公共字符有:a3
str1 = 'abc123'
str2 = 'huak3'
str3 = ''.join([X for X in str1 if X in str2])
print(str3)