Day8_字符串
笔记:
字符串和字符
- 什么是字符串
"""
字符串是容器型数据类型(序列),将''或者""或者''''''或者""""""作为容器标志,里面每一个独立的符号就是字符串的元素。
字符串是不可变的;字符串是有序的(支持下标操作)
字符串的元素:引号里面的每个符号都是字符串的元素,字符串的元素又叫字符;字符分为两种,一种是普通字符,一种是转义字符。
"""
- 空串(引号中什么都没有,空格也不行)
- empty1 = ’ ‘;empty2 = " ";empty3 = ‘’’ ‘’’;empty1 = “”" “”"
- 字符串的容器标志
- ’ ‘和" "没有区别;’’’ ‘’'和""" “”"没有区别
- ’ '和" "里面的内容不能通过直接按回车换行,只能通过转义字符换行;
- ‘’’ ‘’'和""" “”"里面的内容可以通过直接按回车换行
- 字符串的元素 - 字符
"""
字符分为普通字符和转义字符两种
1)普通字符 - 在字符串中表示符号本身的字符
2)转义字符 - 使用\\和其他符号一起来表示特殊功能和意义的字符
\n - 换行
\t - 水平制表符(相当于tab键)
\' - 表示一个普通的单引号
\" - 表示一个普通的双引号
\\ - 表示一个普通的反斜杠
3)阻止转义 - 让字符串中所有的转义字符功能消失(让字符串中每一个字符都表示本身)
在字符前面加R/r:如:R''或者r''
4)转义字符-编码字符
"""
- \u4位的16进制 - 16进制数的编码字符对应的字符
- 编码值 - 字符编码
- 编码值 - 计算机在储存符号的时候其实存的是这个符号对应的固定数字。这个数字就是符号对应的编码值。
- 1编码表 - 将字符和数字一一对应的表
"""
ASCII码 - 总共128个符号,只有美国常用符号,
数字在字母的前面,大写字母在小写字母前面,大写字母和小写字母之间有间隙
大写字母65-A
小写字母97-a
Unicode编码表 (python) - Unicode编码表中包含ASCII码;
包含了目前世界所有国家所有民族的所有语言文字的符号
中文编码范围:4e00~9fa5
chr(编码值) - 获取编码值对应的字符
ord(字符) - 获取指定字符的编码值(凡是需要字符的地方,都给长度是1的字符串)
编码字符 - \u4e00
"""
- hex - 将其他进制的数据转换成16进制的数据
- bin - 将其他进制的数据转换成2进制的数据
计算机基础
- 内存单位
- 1字节(byte) = 8位(bit) - 程序申请内存的最小单位
- 1Kb = 1024 byte
- 1Mb = 1024Kb
- 1Gb = 1024Mb
- 1Tb = 1024Gb
- 进制
-
计算机中数字常见进制有4种:2进制、8进制、10进制、16进制
-
10进制
""" 基数:0、1、2、3、4、5、6、7、8、9 进位:逢10进1 位权:10**(N-1) 例如:123 =1*10**2+2*10**1+3*10**0 表示方式:、、、 """
-
2进制
""" 基数:0、1 进位:逢2进1 位权:2**(N-1) 例如:101 =1*2**2+0*2**1+1*2**0 表示方式:加前缀0b """
-
8进制
""" 基数:0、1、2、3、4、5、6、7 进位:逢8进1 例如:527 = 5*8**2+2*8**1+7*8**0 位权:8**(N-1) 表示方式:加前缀0o """
-
16进制
""" 基数:0、1、2、3、4、5、6、7/8、9、a/A、b/B、c/C、d/D、e/E、f/F 进位:逢2进1 位权:16**(N-1) 例如:1f=1*16**1+f*10**16**0 表示方式:加前缀0x """
字符串相关操作
-
-
查 - 字符串获取字获取字符和列表获取元素的语法一样
- 一个空格是一个字符
- 一个转义字符是一个字符,长度是1
- 切片:切片规则和列表一样
-
运算符
-
字符串1+字符串2 - 将两个字符串拼接产生一个新字符串
-
字符串*N - 将字符串重复N次产生一个新的字符串
-
比较大小:>、<、>=、<=
两个字符串比较大小比较的是第一对不相等的字符的编码值的大小
""" 是否是数字字符:'0' <= char <= '9' 是否是小写字母:'a' <= char <= 'z' 是否是大写字母:'A' <= char <= 'Z' 是否是字母:'A' <= char <= 'Z' or 'a' <= char <= 'z' 是否是中文:'\u4e00' <= char <= '\u9fa5' """
-
-
in 和not in
- 字符串1 in 字符串2 - 判断字符串2中是否包含字符串1(判断字符串1是否包含字符串2的子串)
-
len、str函数
- str(数据) - 将数据转换成字符串。(任何类型的数据都可以转换成字符串,转换时直接将数据的打印值外直接加引号)
字符串相关方法
-
join
字符串.join(序列) - 将序列中元素适用指定字符串连接产生一个新的字符串。序列中的元素必须是字符串
-
split
1. 字符串.split(字符串2) - 将字符串1中所有的字符串2作为切割点对字符串1进行切割
2. 字符串.split(字符串2,N) - 将字符串1中前N个字符串2作为切割点对字符串1进行切割 -
replace
字符串.replace(old,new ,[max]) - 把 将字符串中的 old 替换成 new,如果 max 指定,则替换不超过 max 次 -
center、rjust、ljust
字符串.center(width, fillchar) - 返回一个指定的宽度 width 居中的字符串,fillchar 为填充的字符,默认为空格
字符串.rjust(width, fillchar) - 返回一个指定的宽度 width 居右边的字符串,fillchar 为填充的字符,默认为空格
字符串.ljust(width, fillchar) - 返回一个指定的宽度 width 居左边的字符串,fillchar 为填充的字符,默认为空格 -
zfill
字符串.zfill(width) - 返回width长度的字符串,如果字符串位数不够,会在前面添零 -
count
count(str, beg= 0,end=len(string)) - 返回 str 在 string 里面出现的次数,如果 beg 或者 end 指定则返回指定范围内 str 出现的次数 -
find、rfind
find(str, beg=0, end=len(string)) - 检测 str 是否包含在字符串中,如果指定范围 beg 和 end ,则检查是否包含在指定范围内,如果包含返回开始的索引值,否则返回-1
rfind(str, beg=0,end=len(string)) - 类似于 find()函数,不过是从右边开始查找 -
index、rindex
index(str, beg=0, end=len(string)) -跟find()方法一样,只不过如果str不在字符串中会报一个异常
rindex(str, beg=0, end=len(string)) - 类似于 index(),不过是从右边开始 -
isnumeric() - 其中包含数字字符(表示数字含义的单个字符),返还True,否则是False
-
isdigit() - 其中都是数字,返还True,否则返还False
-
lower
lower() - 转换字符串中所有大写字符为小写 -
min\max
min(str) - 返回字符串str中最小的那个字母
max(str) - 返回字符串中str中最大的那个字母 -
rsrip()- 删除字符串中字符串末尾的空格
-
swapcase() - 将字符串中大写字母 转换成小写,小写字母转换成大写
-
upper()- 将字符串中小写字母转换成大写
-
isdecimal() - 检查字符串是否只包含十进制字符,如果是返回 true,否则返回 false。
作业:
1.输入一个字符串,打印所有奇数位上的字符(下标是1,3,5,7…位上的字符)
例如: 输入**'abcd1234 ’ ** 输出**‘bd24’**
str1 = input('输入一个字符串:')
print(''.join([str1[index] for index in range(len(str1)) if index % 2]))
2.输入用户名,判断用户名是否合法(用户名长度6~10位)
str1 = input('输入用户名(用户名长度为6~10):')
if 6 <= len(str1) <= 10:
print('用户名合法!')
else:
print('用户名不合法!')
3.输入用户名,判断用户名是否合法(用户名中只能由数字和字母组成)
例如: ‘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('用户名合法!')
4.输入用户名,判断用户名是否合法(用户名必须包含且只能包含数字和字母,并且第一个字符必须是大写字母)
例如: ‘abc’ — 不合法 ‘123’ — 不合法 ‘abc123’ — 不合法 ‘Abc123ahs’ — 合法
str1 = input('输入用户名(用户名只能由数字和字母组成,并且第一个字符必须是大写字符):')
if 'A' <= str1[0] <= 'Z':
for x in str1:
if '0' <= x <= '9' or 'a' <= x <= 'z' or 'A' <= x <= 'Z':
continue
else:
print('用户名不合法!')
break
else:
print('用户名合法!')
else:
print('用户名不合法!')
5.输入一个字符串,将字符串中所有的数字字符取出来产生一个新的字符串
例如:输入**‘abc1shj23kls99+2kkk’** 输出:'123992’
str1 = input('一个字符串:')
print(''.join([x for x in str1 if '0' <= x <= '9']))
6.输入一个字符串,将字符串中所有的小写字母变成对应的大写字母输出 (用upper方法和自己写算法两种方式实现)
例如: 输入**‘a2h2klm12+’ ** 输出 'A2H2KLM12+'
# 方法一
str1 = input('一个字符串:')
print(str1.upper())
# 方法二
str1 = input('一个字符串:')
print(''.join([chr(ord(x) - 32) if 'a' <= x <= 'z' else x for x in str1]))
7.输入一个小于1000的数字,产生对应的学号
例如: 输入**‘23’,输出’py1901023’** 输入**‘9’, 输出’py1901009’** 输入**‘123’,输出’py1901123’**
str1 = input('输入一个小于1000的数字:')
if len(str1) == 1:
print('学号为:', 'py190100' + str1)
elif len(str1) == 2:
print('学号为:', 'py19010' + str1)
else:
print('学号为:', 'py1901' + str1)
8.输入一个字符串,统计字符串中非数字字母的字符的个数
例如: 输入**‘anc2+93-sj胡说’** 输出:4 输入**’===’** 输出:3
str1 = input('输入一个字符串:')
print(len(str1)-len([x for x in str1 if '0' <= x <= '9' or 'a' <= x <= 'z' or 'A' <= x <= 'Z']))
9.输入字符串,将字符串的开头和结尾变成’+’,产生一个新的字符串
例如: 输入字符串**‘abc123’, 输出’+bc12+’**
str1 = input('输入一个字符串:')
len1 = len(str1)
print(''.join(['+' if index == 0 or index == len1 - 1 else str1[index] for index in range(len1)]))
10.输入字符串,获取字符串的中间字符
例如: 输入**‘abc1234’** 输出:‘1’ 输入**‘abc123’** 输出**‘c1’**
str1 = input('输入一个字符串:')
len1 = len(str1)
len2 = (len1-1)//2
if len1 % 2:
print(str1[len2])
else:
print(str1[len2:len2+2])
11.写程序实现字符串函数find/index的功能(获取字符串1中字符串2第一次出现的位置)
例如: 字符串1为:how are you? Im fine, Thank you! , 字符串2为:you, 打印8
str1 = 'how are you? Im fine,Thank you!'
str2 = 'you'
len1 = len(str2)
for index in range(len(str1)):
if str1[index: index + len1] == str2:
print(index)
break
12.获取两个字符串中公共的字符
例如: 字符串1为:abc123, 字符串2为: huak3 , 打印:公共字符有:a3
str1 = 'how are you? Im fine,Thank you!'
str2 = 'you'
pub = ''
for x in str1:
if x in str2 and x not in pub:
pub += x
print('公共字符有:', pub)