一、字符串的元素
1.元素
- 定义:
Python中,将字符串看出是一个序列(容器),容器中的内容是字符,每一个字符就是元素
2.获取字符
定义:
字符串是一个不可变的有序序列(不可变指的是字符串中的每个字符,以及每个字符的位置不可变),所以通过方法可以将想获取的字符取出-
获取单个字符
语法:字符串[下标] -->根据下标获取字符串中的字符
说明:
a.字符串:可以是字符串的变量,也可以是字符串的值
b.[]:固定写法
c.下标:0~字符串长度-1; -1~-长度例子:
str2 = 'python'
print(str2[0]) #获取第1个字符
print(str2[-6]) #获取倒数第6个字符
#p
#p
- 获取字符串中的部分字符
方法 | 说明 | 注意 |
---|---|---|
字符串[起始下标:结束下标] | 获取字符串中从起始下标开始,到结束下标前的所有的字符 | 起始下标对应的字符要在结束下标之前 |
字符串[起始下标:结束下标:步长] | 获取字符串中从起始下标开始获取,每步长获取一个,到结束下标前为止 | 步长为正(负)从前(后)往后(前)取,起始下标对应的字符要在结束下标之前, |
省略起始下标:字符串[:结束下标] | 从头开始取 | 开头和步长的正负值有关,切片的时候下标可以越界 |
省略结束下标:字符串[起始下标:] | 从起始下标开始取,取完为止 | 开头和步长的正负值有关,切片的时候下标可以越界 |
省略两个下标:字符串[:] | 全部取完 | 开头和步长的正负值有关,切片的时候下标可以越界 |
- 测试:
str4 = '同九年,汝何秀!'
print(str4[1:5])
#九年,汝
str4 = '同九年,汝何秀!'
print(str4[1:5])
#九年,汝
str5 = '海贼王、一拳超人、一人之下、进击的巨人'
print(str5[1:10:2])
print(str5[10:0:-1])
#贼、拳人一
#人一、人超拳一、王贼
str6 = '阁下何不同风起,扶摇直上九万里'
print(str6[:4:1])
print(str6[-4::1])
print(str6[::-1])
#阁下何不
#上九万里
#里万九上直摇扶,起风同不何下阁
二.字符串运算符
1.分类
- python中的字符串支持+、*和比较运算符
方法 | 格式 | 说明 |
---|---|---|
+ | 字符串1 + 字符串2 | 将字符串1和字符串2拼接在一起产生一个新的字符串 |
* | 字符串1 * n(整数) | 字符串1重复n次,产生一个新的字符串 |
比较运算符 | 字符串1 (==,!=,>,<) 字符串2 | 判断相等、比较大小(比较两个字符串相应位置的字符编码的大小,直到字符不相等为止) |
- 例子:
str1 = '玉树临风美少年'
str2 = '揽镜自顾夜不眠'
print(str1 + str2)
print(str1 + " " + str2)
print(str1 + "," + str2)
#玉树临风美少年揽镜自顾夜不眠
#玉树临风美少年 揽镜自顾夜不眠
#玉树临风美少年,揽镜自顾夜不眠
str3 = '家有千金,行止由心!'
print(str3*3)
#家有千金,行止由心!家有千金,行止由心!家有千金,行止由心!
print('abc' == 'abc')
print('abc' != 'abc')
#True
#False
print('abc' > 'bc')
print('zabc' > 'bc')
#False
#True
2.in和not in
用法:
字符串1 in 字符串2 -->判断字符串1是否在字符串2中(判断字符串2是否包含字符串1)。例子:
print('ab' in 'abcd')
print('ab' in 'assbcd')
#True
#False
3.len()函数
定义:
python的内置函数,功能是用来获取序列的长度(容器中元素的个数),字符串的长度就是字符串中字符的个数例子:
print(len('hello'))
str4 = '床前明月光\n疑是地上霜!'
print(len(str4))
str4 = r'床前明月光\n疑是地上霜!'
print(len(str4))
str4 = '你好吗?\u4eff\u5cff'
print(len(str4))
print(str4[len(str4)-1]) #str5[5]
#5
#12
#13
#6
#峿
三、格式字符串
定义:字符串的内部通过格式占位符来表示字符串中变化的部分,然后在后面用值来填充变化的部分
作用:按格式对字符串进行拼接
语法:带有占位符的字符串 %(给占位符赋值的值)
注意:前面有多少个占位符,后面()中就必须有多少值,并且值的个数和值的类型要和前面的占位符一一对应
分类·:
符号 | 意义 |
---|---|
%s | 字符串 |
%d | 整数 |
%f | 小数 |
%f.nf | 保留小数点后n位小数 |
%c | 显示数字对应的字符 |
- 例子:
name = '张三'
age = 18
money = 10.5
# message = '姓名:'+name+'年龄:'+str(age)+'薪资'+str(money)
message = '姓名: %s 年龄: %d 薪资: %f' %(name,age,money)
print(message)
#姓名: 张三 年龄: 18 薪资: 10.500000
四、字符串内置函数
- python内部给我们提供很多字符串相关的方法,使用方式:字符串.方法名(参数)
函数 | 变量内容 | 用法 | 函数名称 |
---|---|---|---|
capitalize() | 字符串 | 字符串.capitalize() | 将字符串的第一个字符转换为大写 |
center(width,fillchar) | width字符串的长度,fillchar新的字符串的总共的长度剩下部分填充的字符 | 字符串.center(width,fillchar) | 字符串居中对齐 |
ljust(width,fillchar) | width字符串的长度,fillchar新的字符串的总共的长度剩下部分填充的字符 | 字符串.ljust(width,fillchar) | 字符串左对齐 |
rjust(width,fillchar) | width字符串的长度,fillchar新的字符串的总共的长度剩下部分填充的字符 | 字符串.rjust(width,fillchar) | 字符串右对齐 |
count() | 字符串 | 字符串1.count(字符串2) | 显示数字对应的字符 |
endswith() | 字符串 | 字符串1.endswith(字符串2) | 判断字符串1是否以字符串2结尾 |
startswith() | 字符串 | 字符串1.startswith(字符串2) | 判断字符串1是否以字符串2开头 |
find | 字符串 | 字符串1.find(字符串2) | 在字符串1中查到字符串2,返回第一个的开始下标,没有就返回-1 |
isnumeric() | 无 | 字符串.isnumeric() | 判断字符串是不是由数字组成 |
istitle() | 无 | 字符串.istitle() | 判断字符串是否为标题 |
join() | 字符串 | 字符串1.join(字符串2) | 将字符串1插入到字符串2中每个字符之间 |
- 例子:
str1 = 'love'
new_str1 = str1.capitalize()
print(new_str1)
#Love
str2 = 'dog'
new_str2 = str2.center(7,"0")
print(new_str2)
new_str2 = str2.ljust(7,"0")
print(new_str2)
new_str2 = str2.rjust(7,"0")
print(new_str2)
#00dog00
#dog0000
#0000dog
# 练习:根据进班的顺序号产生对应的学号,学号要求:
# 例如:num = 1 --->py18070001 num = 11 --->py18070011 num = 102 --->py18070102
num = '1'
new_num = 'py1807' + num.rjust(4,"0")
print(new_num)
#py18070001
print('abcdabcdaaa'.count('ab'))
print('hello world'.count('l'))
#2
#3
str1 = 'when i was'
print(str1.endswith('was'))
print(str1.endswith('when'))
#True
#False
str2 = 'when i was young,i have a dream'
print(str1.find('was'))
print(str1.find('waszz'))
#7
#-1
print('123'.isnumeric())
print('一二五'.isnumeric())
print('二百五'.isnumeric())
print('壹'.isnumeric())
#True
#True
#True
#True
print('The'.istitle())
#True
print('the'.join('she'))
#sthehthee
作业
- 个性化消息: 将用户的姓名存到一个变量中,并向该用户显示一条消息。显示的消息应非常简单,如“Hello Eric, would you like to learn some Python today?”。
解答:
name = 'faker'
print('"Hello ' + name + ', would you like to learn some Python today?"')
- 调整名字的大小写: 将一个人名存储到一个变量中,再以小写、大写和首字母大写的方式显示这个人名。
解答:
name = "clearlove7"
print(name.title())
print(name.upper())
print(name.lower())
- 名言: 找一句你钦佩的名人说的名言,将这个名人的姓名和他的名言打印出来。输出应类似于下面这样(包括引号):Albert Einstein once said, “A person who never made a mistake never tried anything new.”
解答:
str1 = 'Albert Einstein once said, “A person who never made a mistake never tried anything new.”'
print(str1)
- 名言2: 重复练习2-5,但将名人的姓名存储在变量famous_person 中,再创建要显示的消息,并将其存储在变量message 中,然后打印这条消息。
解答:
famous_person = 'Albert Einstein'
message = famous_person + ' once said, “A person who never made a mistake never tried anything new.”'
print(message)
- 剔除人名中的空白: 存储一个人名,并在其开头和末尾都包含一些空白字符。务必至少使用字符组合"\t" 和"\n" 各一次。 打印这个人名,以显示其开头和末尾的空白。然后,分别使用剔除函数lstrip() 、rstrip() 和strip() 对人名进行处理,并将结果打印出来。
解答:
name = ' fa\tke\nr '
print(name)
name1 = name.rstrip() #剔除字符串末尾的空白,
print(name1)
name2 = name.lstrip() #剔除字符串开头的空白
print(name2)
name3 = name.strip() #剔除字符串两端的空白
print(name3)