1.什么是字符串
a. 使用单引号或者双引号括起来的字符集就是字符串。
b. 引号中单独的符号、数字、字母等叫字符。
c. 转义字符:可以用来表示一些有特殊功能或者是特殊意义的字符(通过在固定的字符前加\)。
' ---> 表示打印 '
\ ---> 表示打印
\n ---> 换行
\t ---> 制表符
注意: 在计算字符串长度的时候,转义字符代表一个字符。
字符串举例:
'123'
'abcd'
'%(kjd*^'
'中文汉字'
' ' ---> 空格也是字符串
2.阻止转义
可以通过在字符串前面加r或者R,来阻止转义字符的转义。
如:str4 = r'\1\n22'
3.Python中字符串中的字符是Unicode编码
Unicode编码:使用16位对一个字符进行编码。编码的目的是让字符可以存储到计算机中。
Unicode码中包含了ASCII码,可以表示世界上所有的语言和符号。
a. 获取一个字符的Unicode码
ord1 = ord('魏')
ord2 = ord('盼')
print (hex(ord1),hex(ord2))
结果:
0x9b4f 0x76fc
b. 将Unicode码转换成字符
chr(编码值)
print (chr(0x9b4f),chr(0x76fc))
结果:
魏 盼
4.字符串大小的比较
字符串比较大小的时候,从字符开始,依次往后比较每个字符的大小,直到遇到字符不一样为止。
比较字符大小的时候,实质比的是他们的编码大小。
例如:
print ('abc' > 'aa')
print ('Zbc' > 'aa')
print ('ab' > 'a')
结果:
True
False
True
5.如何获取字符串中的字符
Python的字符,实质是一个有序的字符序列。
- 获取字符串的长度:(长度 ---> 字符串中字符的个数)
len是获取序列长度的内置函数
count = len('abc\n123')
print (count)
结果:
7
- 通过下标获取字符串中的某一个字符
字符串中每个字符都对应一个下标(索引),我们可以通过索引值去获取固定的字符。
'abc' ---> a:0, b:1, c:2
str1 = 'abc'
print (str1[1])
结果:
b
str2 = 'good good study\nday day up'
print (str2[25])
结果:
p
注意:下标的范围:0 ~ 字符串的长度-1 ; -1 ~ - 字符串长度。
获取字符的时候,索引值不能超出索引的范围,超出范围报错。
print (str1[-1]) --->获取字符串str1中的最后的字符。
print (str1[-2]) --->获取字符串str1中的倒数第二个字符。
- 获取字符串中的部分字符(切片):
字符串[开始下标:结束下标] ---> 获取字符串中从开始下标到结束下标的字符(包含开始但不包含结束下标)
字符串[开始下标:结束下标:步进]
字符串[开始下标:结束下标] == 字符串[开始下标:结束下标:1]
a. 开始下标对应的字符,要在结束下标对应的字符前面(步进为正)
str3 = 'hello Python'
print (str3[6:12])
print (str3[-6:12])
都打印出了Python
Python
Python
b. 开始下标省略:从字符串的最前面取到结束下标前
print (str3[:5])
hello
c. 结束下标省略:从开始位置获取到字符串结束
print (str3[4:])
o Python
d. 两个都省略:获取整个字符串的内容
print (str3)
hello Python
e. 每两个取一个(步进为2)
print (str3[::2])
hloPto
f. (了解)步进为负,开始下标和结束下标的性质相反
print (str3[3:1:-1])
print (str3[::-1]) ---> 字符串倒序
结果:
ll
nohtyP olleh
6. +:字符串拼接
举例:
str1 = 'hello' + ' ' + 'Python'
print (str1)
结果:
hello Python
注意:+ 两边要么都是数字要么都是字符串,不能是一个数字一个字符串
例如:
print (12 + '23')
错误
7. *:字符串重复
字符串 * 整数
str1 = 'abc' * 3
print (str1)
结果:
abcabcabc
8. in
字符串1 in 字符串2 : 判断字符串1是否在字符串2中 ---> 在就是True,不在False
result = 'aa' in 'baabc'
print (result)
结果:
True
9. not in
字符串1 not in 字符串2 : 判断字符串1是否不在字符串2中 ---> 不在为True,在为False
10.格式字符串
格式:'占位符1占位符2'%(值1,值2)
举例:
str1 = 'abc%s1%s23' % ('>>>','!!')
print (str1)
结果:
abc>>>1!!23
%s ---> 字符串占位(格式符)
%d ---> 整数占位符(格式符)
%f ---> 浮点数占位符
%c ---> 长度是1的字符串占位符(字符占位符)---可以给一个字符,也可以给字符的编码值
str2 = '-%s-%d-%f-%c-%c' % ('字符串',123,12.4,'k',97)
print (str2)
结果:
-字符串-123-12.400000-k-a
%.nf : 使用n值限制小数点后面的小数的位数(默认六位小数)
str3 = '金额:%.2f元' % (100)
print (str3)
结果:
金额:100.00元
如果后面没有加%,那么这个字符串只是一个普通的字符串
str4 = '金额:%.2f元'
print (str4)
结果:
金额:%.2f元
11. 格式化输出
name = '魏盼'
age = 18
xx今年xx岁
print ('%s今年%d岁' % (name,age))
结果:
魏盼今年18岁
12. 字符串相关方法的通用格式:字符串.函数()
- capitalize:将字符串的首字母转换成大写字母,并且创建一个新的字符串返回
str1 = 'abc'
new_str = str1.capitalize()
print(str1,new_str)
结果:
abc Abc
- center(width,fillchar):将原字符串变成指定的长度并且内容居中,剩下的部分使用指定的字符串填充
new_str = str1.center(9,'*')
print (str1,new_str)
结果:
abc ***abc***
- rjust(width,fillchar):右对齐
new_str = str1.rjust(7,'*')
print (new_str)
结果:
****abc
练习:打印出py1805019
a. 产生学号
number = 19
b. str(数据):将任何其他的数据转换成字符串
num_str = str(number)
c. 让字符串变成宽度为3,内容右对齐,剩下部分使用'0'填充
new_str = num_str.rjust(3,'0')
print (new_str)
new_str = 'py1805' + new_str
print (new_str)
结果:
019
py1805019
- ljust(width,fillchar):左对齐
str1 = 'py'
new_str = str1.ljust(5,'*')
print (new_str)
结果:
py***
- 字符串1.join(字符串2):在字符串2中的每个字符之间插入一个字符串1
new_str = '*'.join('bbb')
print (new_str)
结果:
b*b*b
13. if语句
结构:
- if 条件语句:
---------条件语句结果为True执行的代码块
执行过程:先判断条件语句是否为True,如果为True就执行if语句后:后面对应的一个缩进的所有的代码。
为False就不执行冒号后面一个缩进中的代码块,直接执行后续的其他语句。
条件语句:可以是任何有值的表达式,但是一般是布尔值。
if:关键字
if True:
print('代码1')
print('代码2')
print('代码3') # 不管if语句条件是否成立,都要执行这句
结果:
代码1
代码2
代码3
练习:用一个变量保存时间(50米短跑),如果时间小于8秒,打印及格。
time = 7
if (time < 8):
print ('及格') # 只有条件成立的时候才会执行
结果:
及格
- if 条件语句:
------语句块1
else:
------语句块2
执行过程:先判断条件语句是否为True,如果为True就执行语句块1,否则执行语句块2。
练习:用一个变量保存成绩,如果成绩大于等于60,打印及格,否则打印不及格。
score = 59
if score >= 60:
print('及格')
else:
print('不及格')
结果:
不及格
作业:
- 个性化消息:
将用户的姓名存到一个变量中,并向该用户显示一条消息。显示的消息应非常简单,
如“Hello Eric, would you like to learn some Python today?”。
name = 'Eric'
message = 'Hello %s,would you like to learn some Python today?' %(name)
print(message)
结果:
Hello Eric,would you like to learn some Python today?
- 调整名字的大小写:
将一个人名存储到一个变量中,再以小写、大写和首字母大写的方式显示这个人名。
name = 'WeiPan'
name1 = name.lower()
name2 = name.upper()
name3 = name.title()
print(name1)
print(name2)
print(name3)
结果:
weipan
WEIPAN
Weipan
- 名言:
找一句你钦佩的名人说的名言,将这个名人的姓名和他的名言打印出来。
输出应类似于下面这样(包括引号):
Albert Einstein once said, “A person who never made a mistake never tried anything new.”
saying = 'Albert Einstein once said, “A person who never made a mistake never tried anything new.”'
print(saying)
结果:
Albert Einstein once said, “A person who never made a mistake never tried anything new.”
- 名言2:
重复练习3,但将名人的姓名存储在变量famous_person 中,
再创建要显示的消息,并将其存储在变量message 中,然后打印这条消息。
famous_person = 'Albert Einstein'
message = '“A person who never made a mistake never tried anything new.”'
new_message = '%s once said,%s' %(famous_person,message)
print(new_message)
结果:
Albert Einstein once said,“A person who never made a mistake never tried anything new.”
- 剔除人名中的空白:
存储一个人名,并在其开头和末尾都包含一些空白字符。
务必至少使用字符组合"\t" 和"\n" 各一次。
打印这个人名,以显示其开头和末尾的空白。
然后,分别使用剔除函数lstrip() 、rstrip() 和strip() 对人名进行处理,
并将结果打印出来。
name = '\tweipan\n'
print(name)
name1 = name.lstrip()
print(name1)
name2 = name.rstrip()
print(name2)
name3 = name.strip()
print(name3)
结果:
weipan
weipan
weipan
weipan