一、字符串中的元素
1.阻止转义
在字符串的最前面可以添加r/R来阻止字符串中的转义字符转义。
代码
str1 = r'how are you\n fine'
str2 = R'\t你好吗?'
print(str1)
print(str2)
测试结果
2.python中可以把字符串看成是一个序列(容器),容器中的内容是字符,每一个字符可以称为字符串中的元素。
字符串是一个不可变、有序的序列,(不可变指的是字符串中的每个字符,以及每个字符的位置不可变)
例子
str1 = '你好'
str2 = 'hello'
str3 = '你好,world!'
3.获取字符串中的单个字符
语法:字符串[下标] ---> 根据下标获取字符串中的字符
说明:
a.字符串:可以是字符串的变量,也可以是字符串值
b.[]:固定写法
c.下标:0~字符串长度-1; -1 ~ -长度
注意:下标是整数;下标不能越界
python中每个字符串中的字符都会对应一个下标,下标是根据字符在字符串中的位置,从前往后依次增加的(第一个值是0)
代码
str3 = 'python'
# p->0 y->1 t->2 h->3 o->4 n->5
# n->-1 o->-2 h->-3 t->-4 y->-5 p->-6
print(str3[0])
print(str3[-6])
print(str3[4]) #获取倒数第4+1个字符(元素)
print(str3[-2]) #获取倒数第2个字符(元素)
print('hello'[-1])
index = 2
print(str3[index])
print(str3[6//2])
测试结果
练习:获取'good good study\n day day up!'中的第4个d
注意:一个空格算一个字符,一个转义字符算一个字符,一个制表符也是算一个字符。
代码
str4 = 'good good study\n day day up!'
print(str4[17],str4[-11])
测试结果
4.获取字符串中的部分字符(切片)
a.
**语法:字符串[起始下标:结束下标] --->获取字符串中从起始下标开始到结束下标前的所有的字符。
默认步长为1。
注意:起始下标对应的字符要在结束下标对应的字符的前面,否则取不到值
代码
str5 = '同九年,汝何秀!'
print(str5[1:5])
print(str5[5:-1])
测试结果
b.
语法:字符串[起始下标:结束下标:步长] --->从起始下标开始获取,每步长获取一个,获取到结束下标前为止。
步长为正:从前往后取(起始下标对应的字符要在结束下标对应的字符的前面,否则取不到值)
步长为负:从后往前取(起始下标对应的字符要在结束下标对应的字符的后面,否则取不到值)
代码
str5 = '海贼王、一拳超人、一人之下、进击的巨人'
print(str5[1:10:2]) #贼、拳人一
print(str5[10:0:-1]) #人一、人超拳一、王贼
测试结果
c.切片时下标可以省略,省略不同的下标有不同的意义
省略起始下标: 字符串[:结束下标] --->从开头开始取(注意:这儿开头可能是第一个字符也可能是最后一个字符)
代码
str6 = '阁下何不同风起,扶摇直上九万里'
print(str6[:4])
print(str6[:4:-1])
测试结果
(1)省略结束下标: 字符串[起始下标:] --->从开始下标取,取完为止。
(2)两个下标都省: 字符串[:] --->全部取完
(3)
注意:切片的时候下标可以越界
代码
str6 = '阁下何不同风起,扶摇直上九万里'
print(str6[-4:])
print(str6[-4::-1])
print(str6[:])
print(str6[::-1]) #产生一个逆序的字符串
print(str6[0:100])
print(str6[-100:3])
测试结果
二、字符串运算符
运算符 | 功能 |
---|---|
+ | 字符串1 + 字符串2 --->将字符串1和字符串2拼接在一起产生一个新的字符串 |
* | 字符串1重复n次,产生一个新的字符串 |
== | 判断两个字符串的值是否相等 |
!= | 判断两个字符串的值是否不相等 |
> | 比较两个字符串中从前往后每个字符的编码值的大小,比较到两个字符不相同为止 |
< | 比较两个字符串中从前往后每个字符的编码值的大小,比较到两个字符不相同为止 |
in | 判断字符串1是否在字符串2中(字符串2中是否包含字符串1),结果是布尔值 |
not in | 判断字符串1是否不在字符串2中(字符串2中是否包含字符串1),结果是布尔值 |
1.字符串的+号运算符
注意:+两边要么都是数字,要么都是字符串,不能一样一个
代码
str1 = '玉树临风美少年'
str2 = '揽镜自顾夜不眠'
print(str1 + str2)
new_str = str1 + ' ' +str2 + '!'
print(new_str)
测试结果
2.字符串的*号运算符
注意:n必须是整数,先算乘再算加。
代码
str1 = '玉树临风美少年'
str3 = '家有千金,行止由心!'
print(str3*3)
str4 = str1 + str3 * 2
print(str4)
测试结果
3.比较运算符
代码
print('abc' == 'abc') #判断两个字符串的值是否相等
print('abc' != 'ab') #判断两个字符串的值是否不相等
print('zbcdef' > 'zab')
print('你好' < 'abc')
char = 'a'
print('0'<=char<='9') # 判断char是否是数字字符
print('a'<=char<='z' or 'A'<=char<='Z') #判断char是否是字母
测试结果
4.in和not in
代码
print('ab' in 'aabc') #True
print('ab' in 'acb') #False
print('ab' not in 'aabc') #False
print('ab' not in 'acb') #True
测试结果
5.len()函数
len()是python内置函数,功能是用来获取序列的长度(容器中元素的个数)
用法:len(序列)
字符串的长度就是字符串中字符的个数。
代码
print(len('hello'))
str5 = '床前明月光\n疑是地上霜!'
print(len(str5))
str6 = r'床前明月光\n疑是地上霜!'
print(len(str6))
str7 = '你好吗?\u4eff\u5cff'
print(len(str7))
print(str7[len(str7)-1]) #str7[5]
print(str7[-len(str7)]) #str7[-6]
测试结果
三、格式字符串
1.字符串的内部,通过格式占位符来表示字符串中变化的部分,然后在后面用值来填充变化的部分。
2.语法:带有占位符的字符串 %(给占位符赋值的值)
注意:前面有多少个占位符,后面()中就必须有多少个值,并且值的个数和值的类型要和前面的占位符一一对应。
占位符 | 功能 |
---|---|
%s | 字符串 |
%d | 整数 |
%f | 小数 |
%.nf | 保留小数点后n位小数(五舍六入) |
%c | 字符 |
代码
name = '李四'
age = 20
money = 10.567
message = '姓名:%s 年龄:%d 薪资:%.2f' %(name,age,money)
print(message)
print('%d:%c' %(97,97))
测试结果
四、字符串内置函数
python内部给我们提供很多字符串相关的方法,使用方式:字符串.方法名(参数)
1.capitalize() : 将字符串的第一个字符转换为大写,返回一个新的字符串
注意:如果第一个字符不是字母,就不转换
代码
str1 = 'love'
new_str = str1.capitalize()
print(new_str)
测试结果
2.字符串对齐
a.center(width,fillchar)
b.ljust(width,fillchar)
c.rjust(width,fillchar)
width ---> 长度,新的字符串的总共的长度
fillchar---> 剩下部分填充的字符。字符就是长度是1的字符串
代码
str2 = 'XXX'
new_str = str2.center(7,'0')
print(new_str)
new_str = str2.ljust(7,'0')
print(new_str)
new_str = str2.rjust(7,'0')
print(new_str)
测试结果
练习:根据进班的顺序号产生对应的学号,学号要求:
例如:num = 1 ----> py18070001 num = 11 ----> python18070011 num = 102 ----> python18070102
代码
num = 11
new_number = 'py1807'+str(num).rjust(4,'0')
print(new_number)
测试结果
3.字符串1.count(字符串2)--->统计字符串1中字符串2的个数
代码
print('abcdabcdaaa'.count('ab'))
print('hello world'.count('l'))
测试结果
4.
字符串1.endswith(字符串2) ---> 判断字符串1是否以字符串2结尾
字符串1.startswith(字符串2) ---> 判断字符串1是否以字符串2开头
代码
str1 = 'when i was'
print(str1.endswith('as'))
print(str1.endswith('when'))
测试结果
5.字符串1.find(字符串2) ---> 在字符串1中查找字符串2,返回第一个的开始下标。如果没有就返回-1
代码
str1 = 'when i was young,i hava a dream'
print(str1.find('was'))
print(str1.find('wasaa'))
测试结果
6.isnumeric()
代码
print('1234'.isnumeric())
print('一百'.isnumeric())
测试结果
7.istitle():每个单词首字母大写,其他字母小写
代码
print('The One'.istitle())
测试结果
8.字符串1.join(字符串2) --->将字符串1插入到字符串2中每个字符之间,产生一个新的字符串
代码
print('aaa'.join('xyz'))
测试结果
五、作业
1.个性化消息: 将用户的姓名存到一个变量中,并向该用户显示一条消息。显示的消息应非常简单,如“Hello Eric, would you like to learn some Python today?”。
代码
name = 'Mike'
print('Hello ' + name + ',would you like to learn some Python today?')
测试结果
2.调整名字的大小写: 将一个人名存储到一个变量中,再以小写、大写和首字母大写的方式显示这个人名。
代码
name = 'Mike'
print(name.lower())
print(name.upper())
print(name.capitalize())
测试结果
3.名言: 找一句你钦佩的名人说的名言,将这个名人的姓名和他的名言打印出来。输出应类似于下面这样(包括引号):Albert Einstein once said, “A person who never made a mistake never tried anything new.”
代码
message = 'Benjamin Franklin once said,\"Early to bed and early to rise, \
makes a man healthy, wealthy, and wise.\"'
print(message)
测试结果
4.名言2: 重复练习2-5,但将名人的姓名存储在变量famous_person 中,再创建要显示的消息,并将其存储在变量message 中,然后打印这条消息。
代码
famous_person = 'Benjamin Franklin'
message = 'once said,\"Early to bed and early to rise, makes a man healthy, wealthy, and wise.\"'
print(famous_person + message)
测试结果
5.剔除人名中的空白: 存储一个人名,并在其开头和末尾都包含一些空白字符。务必至少使用字符组合"\t" 和"\n" 各一次。 打印这个人名,以显示其开头和末尾的空白。然后,分别使用剔除函数lstrip() 、rstrip() 和strip() 对人名进行处理,并将结果打印出来。
代码
name = ' \tMike \n '
print(name)
# 方法1:
new_name = name.lstrip()
new_name = new_name.rstrip()
print(new_name)
#方法2:
new_name2 = name.strip()
print(new_name2)