字符串
a.使用单引号或者双引号括起来的字符集就是字符串
b.引号中单独的符号,数字,字母等叫字符
c.转义字符:可以用来表示一些有特殊功能或者特殊意义的字符(通过在固定的字符前加\)
注意:所有转义字符在计算字符串长度的时候,转义字符代表一个字符
'------>'
\------->
\n------->换行
\t-------->制表符
str1="\'"
print(str1)
结果:'
2.阻止转义
可以通过在字符串前面加r或者R,来阻止转义字符转义
str1=r"\\"
print(str1)
结果:\
3.python中字符串中的字符是Unicode编码
Unicode编码:使用16位对一个字符进行编码。编码的目的是让字符可以存储到计算机中
Unicode码中包含ASSCII码,可以表示直接上左右的语言和符号
a.获取一个字符的Unicode码
m1=ord("曾")
m2=ord("成")
print(hex(m1),hex(m2))
结果:0x66fe 0x6210
b.将Unicode码转换成字符
chr(编码值)
print(chr(0x4efe))
结果:仾
3.字符串比较大小的时候,从字符开始依次往后比较每个字符的大小,自到遇到字符不一样为止
注意:比较字符大小的时候,实质比较的是他们的编码的大小
print('a'>'ab')
结果:False
获取字符串中的字符
python的字符,实质是一个有序的字符序列
1.获取字符串长度:(长度------>字符串中字符的个数)
len是获取序列长度的内置函数
str1=len("123dsdada")
print(str1)
结果:9
2.通过下标获取字符串中的某一个字符
字符串中每个函数对应一个下标(索引),我们可以通过索引值去获取固定的字符:
str1="123dsdada"
print(str1[0])
结果:1
str1="good good study\nbday day up"
print(str1[-1])
结果:p
注意:转义字符占一位
获取字符时,索引值不能超过索引的范围,否则会报indexError错误
3.获取字符串中的部分代码
a.字符串[开始下标:结束下标]----->获取字符串中从开始下标到结束下标的字符(包含开始下标,不包含结束下标)
注意:开始下标对应的字符,要在结束下标对应的字符前面
str1="good good study\nbday day up"
print(str1[2:6])
结果:od g
str1="hello python"
print(str1[-6:12])
结果:python
b.开始下标省略:从字符串的最前面取到结束下标前
print(str1[:4])
c.结束下标省略:从开始位置获取到字符串结束
print(str1[4:])
d.二个下标都省略:获取整个字符串的内容
print(str1[:])
- 字符串[开始下标:结束下标:步进]
当步进为负数时,开始下标和结束下标的性质相反
str1="hello python"
print(str1[3:1:-1])#3 3-1=2 2-1=1 0
结果:ll
str1="hello python"
print(str1[6:0:-1])
结果:p olle
str1="hello python"
print(str1[6::-1])
结果:p olleh
注意:
print(str1[::-1])#字符串倒序
字符串拼接
1.字符串1+字符串2
注意:+号二边要么都是数字,要么都是字符串。不能用一个数字,一个字符串
2.字符串*整数
str1*10
print(str1)
3.in
字符串1 in 字符串2:判断字符串1是否在字符串2中------>在就是True,不在是Fasle
4.not in
字符串1 not in 字符串2:判断字符串1是否不在字符串2中------>不在就是True,在是Fasle
5.格式字符串
格式:'占位符1占位符2'%(值1,值2)
str1='abc%swe%s33'%('efg','ok')
print(str1)
结果:abcefgweok33
a.%s------>字符串占位符(格式符)
b.%d------>整数占位符(格式符)
c.%f------->浮点数占位符()
d.%c------>长度是1的字符串占位符(字符占位符)
str2='-%s-%d-%f-%c'%('我是字符串',123,12.3,'h')
print(str2)
结果:-我是字符串-123-12.300000-h
e.%.nf:使用n值限制小数点后面的小数的位数(默认六位小数)
str3='金额:%.2f元'%(100)
如果后面没有加%,那么这个字符串只是一个普通的字符串
%x和%X------>十六进制数据占位符
xxx的十六进制是xxxxx
str4='%d的十六进制是0X%x'%(number,number)
print(str4)
结果:15的十六进制是0Xf
字符串相关方法
字符串相关方法的通用格式:字符串.函数()
a.capitalize()
str6='efg'
new_str6=str6.capitalize()
print(str6,new_str6)
结果:efg Efg
b.center(width,fillchar)
Python center() 返回一个原字符串居中,并使用空格填充至长度 width 的新字符串。默认填充字符为空格。
str6='efg'
new_str6=str6.center(7,'T')
print(new_str6)
结果:TTefgTT
c.产生学号
rjust() 右对齐
number=9
num_str=str(number)
new_str=num_str.rjust(3,'0')
print('py1805'+new_str)
结果:py1805009
d.
ljust() 左对齐
number=9
num_str=str(number)
new_str=num_str.ljust(3,'0')
print('Py1805'+new_str)
结果:Py1805900
e.字符串1.join(字符串2):在字符串2中的每个字符之间插入一个字符串1
new_str='123'.join('bbb')
print(new_str)
结果:b123b123b
if语句
1.if条件语句:
条件语句结果为True执行的代码块
执行过程:先判断条件语句是否为True,如果True就执行if语句后面:后面对应的一个缩进的所有代码。为Flase,就不执行冒号后面一个缩进中的代码块,直接执行后续的其他语句
条件语句:可以是任何有值的表达式,但是一般是布尔值
if:关键字
if True
print('代码1')
print('代码2')
print('代码3')
print('代码4')
aoli=10
if aoli>8:
print("成绩及格")
结果:成绩及格
- if 条件语句:
语句块1
else:
语句块2
执行过程:先判断条件语句是否为True,如果为True就执行语句块1,否则就执行语句块2
aoli=5
if aoli>8:
print("成绩及格")
else:
print('成绩不及格')
结果:成绩不及格
补充:
a.print函数可以同时打印多个内容,多个内容之间用逗号隔开,打印的时候,多个内容之间默认是使用空格隔开的
b.lstrip()删除字符串左边的空白,删除指定的元素
str1='-a+!ef'
print(str1.lstrip('-+!'))
结果:a+!ef
删除字符串左边的lstrip()里包含的字符