总结7-31

1.获取字符 - 和列表获取元素一样

str1 = 'spider man'

1)获取单个字符

print(str1[0]) # 's'

2)字符串切片

print(str1[2:6:2]) #'ie'
print(str1[2:6:-2])
print(str1[3:])

3)遍历

for char in 'grass':
print(char)

Practise:统计一个字符串中小写字母的个数

str2 = 'How Are You ! Im Fine, THANK YOU!'
count = 0
for chr in str2:
if 97 <= ord(chr) <= 122:
count += 1
print(count)

2.字符串操作

1)+ 和 *

字符串1 +字符串2 - > 将字符串1和2 拼接在一起产生一个新字符串

字符串 * N / M * 字符串 - > 字符串重复N 次产生新字符串

str1 = 'fullofstar'
str2 = 'yoursky'
print(str1*3) #

2) ==, !=

print('complete' == 'complete')

3>, <, >=, <=

只能两个字符串比较大小 - 从前往后找到第一组不当灯的字符,比价它们编码的大小,谁的编码值大那个字符串就大

'0' <= char <= '9' - 判断是否是数字字符

'a' <= char <= 'z' - 判断是否是小写字母

'u4e00' <= char <= 'u9fa5' - 判断是否是中文

'a' <= char <= 'z' ot 'A' <= char <= 'Z' - 判断是否是字母

print('shine' > 'shining')

print('abcf' > 'abca')
print('')

4) in / not in

字符串1 in 字符串2 -> 判断字符串2 中是否包含字符串1(判断字符串1是否是字符串2的子串

str3 = 'As long as you love me '
print('long' in str3)
print('ma' in str3)

5) len, max, min, sorted, str

所有的数据都可以转换成字符串,转换的时候是将数据放在引号中

print(len(str3))

注意:转义字符串和编码字符的长度都是1

str3 = '\u4effAs long as you love me'
print(len(str3))

str3 = 'As long as you love me '
print(max(str3))

print(sorted(str3))

6) r 语法

在字符串的最前面加小写的r或R,可以阻止字符串中所有的转义字符转义

str1 = '\tthrow\nrubbish\u4e00'
print(str1, len(str1))

str1 = R'\tthrow\nrubbish\u4e00'
print(str1, len(str1))

7) 格式字符串

在字符串中用格式占位符表示字符串中不确定的部分

a.语法:包含格式占位符的字符 % (数据1,数据2,...) ()中数据的个数和类型要和前面格式占位符一一对应

b.格式占位符:

%s - 字符串

%d - 整数

%.Nf - 浮点数,N控制小数点后小数的位置

%c - 字符(可以将数字转换成字符)

ATTENTION:所有的数据都可以用%s来做个数占位符 2)所有的数据都可用%s来接收

name = input('Enter your name:')

age = int(input('Enter your age:'))

gender = input('Enter gender:')

message = '%sCome back!' % name

print(message)

str4 = 'a: %s,b: %d, c: %f' % ('POWER', 100, 3.14)
print(str4)

str5= "{}{}".format("draw","circle")
print(str5)


1.什么是字符串(str)

字符串是容器型数据类型(序列); 以单引号或者双引号作为容器的标志,引号中所有的内容都输入字符串的元素

'abc' -> 元素分别是'a', 'b', 'c' 3个元素

'a, b, c' -> 元素分别是 5个元素

特点:不可变,有序(支持下标操作)

2)字符串中的元素

字符串中元素叫字符(注意:python中没有字符的概念,但是没有字符的类型;长度是1的字符串就可以看成字符)

a.普通字符:字符、数字、global文字和字符等号(可以写在引号中的符号)

'attention', 'figure',

b.转义字符:在字符串中在一些特定的符号前加\来表示特殊的功能和意义

' - ' ; " - " ; \n - ENTER ; \t -TAB(制表符)

c.编码字符:\u 4位16进制数 - 将四位16进制数对应的编码值转换成字符

1)字符编码

计算机只有直接存储数字的能力,不能直接存储字符;当需要用机算计存储字符的时候,实质存储的是字符对应的固定的数字,这个数字就是字符在计算机的编码

每一个字符和数字的对应关系叫编码表

2)ASCII编码表和Unicode编码表

ASCII码表是有美国国家标准制定的专门针对美国的符号进行编码,面值包含一些特殊符号、字母和数字(不包含中文、日语、韩语等)

python采用的是Unicode编码表:Unicode编码表是对ASCII表的扩展,包含了世界上所有国家的所有语言的符号(又称万国码)

中文范围:0x4e00-0x9fa5

3)字符编码相关方法

chr(编码值) - 将编码值转换成字符

ord(字符) - 获取字符对应的编码值

1.字符串中的内容

2.字符编码

print(chr(0x1800))
for x in range(0x1100, 0x11ff):
print(chr(x), end='')

num = 0

for x in range(0x4e00, 0x9fa5):

num += 1

print(chr(x), end='')

if num %35 == 0:

print()

print()

ord()


1.字符串对齐方法

字符串.center(宽度,填充字符= '') - 居中

字符串.ljust(宽度,填充字符= ’‘) - 左对齐

字符串.rjust(宽度,填充字符= ’‘)

字符串.zfill(宽度) == 字符串.rjust(宽度,0)

str1 = 'construction'
print(str1.center(20, 'p'))
print(str1.ljust(20, 'o'))
print(str1.rjust(20, 'p'))
print(str1.zfill(20))

2.统计子串的个数

字符串1.count(字符串2) - 统计字符串1种字符串2出现的次数

str1 = 'Do you wanna build snow man?'
print(str1.count('n')) # 4
print(str1.count('you',0, 12)) # 在下标是[0, 12)范围内统计'you'的个数

print(str1.find('you'))
print(str1.index('you'))
print(str1.find('you1')) # 1

print(str1.index('you1')) # substring not found

4.join方法

字符串.join(序列) - 将序列中的元素用字符串连接产生一个新的字符串

要求序列中的元素必须是字符串,如果是字典Key是字符串

new_str1 = '+'.join('CcC')
print(new_str1) # C+c+C

new_str1 = ''.join(['Lisa', 'Ashin', 'ugly'])
print(new_str1) # LisaAshinugly

5.替换

字符串1.replace(字符串2,字符串3) - 将字符串1种的所有字符串2都替换成字符串3

字符串1.replace(字符串2,字符串3, N) - 将字符串1中前N个字符串2都替换成字符串3

6.字符串切割

字符串1.split(字符串2) - 将字符串2作为切割点 切割字符串1 返回一个列表

str1 = 'Will you marry me?'
str_list = str1.split('?')
print(str_list) # ['Will you marry me', '']

你可能感兴趣的:(总结7-31)