一.字符串
单双引号,字符串是有序的,但是是不可变的
python中只有这个概念没有对应的数据的类型,引号里面只有一个元素的字符串可以看成一个字符。
1.普通的字符:
原则上可以通过键盘输入或则从其他地方复制粘贴的都可以作为字符。
普通字符:在字符串中能过代表符号本身的字符。(没有特殊意义和特殊功能的字符)。
2.转义字符:
在字符串中有特殊意义和功能的符号的组合,一般是以\开头的
\n -----换行
\ ------ 表示 引号 本身
\t ----- 表示一个缩进,就是一个tab键
\ ------表示一个反斜杆,特殊的意义消失
\u四位的16进制数--字符--获取编码值对应的字符(编码)--获取四位十六进制数作为编码值对应的字符。
str6="abc"
abc='st'r'
注意所有的转义字符的长度都是一。
print("\uaa72")
3阻止转义:
在字符串的最前面加r/R,可以让当前的所有的转义的字符都是失效的,所有的符号都是表示他本身
str=r'\tabc\n\'123'
str2='\tabc\n\'123'
print(str2)
'123
\tabc\n\'123
4字符的编码:
计算不能直接存储字符(符号),只能存储数字,为了能够存储字符。
把每一个字符关联了一个固定的数字(这个固定的数字就是数字的编码)
"a"----存编码值97
字符和数字一一对应的关系的表:ASCII码表,Unicode编码表(python)
Unicode编码表是ASCII码表扩展。
(1)ASCII码表--在计算中采用一个字节保存一个字符,字符包含了所有的字母,数字和美国常用的符号(128个字符)。
数字48开始到57,0--9 大写字母的编码值小于小写的, 大写---65到90,小写-97--122,范围0-127
(2)Unicode编码表---万国码
Unicode编码表:包含了世界上所有的国家所有的语言对应的符号。总共有65356个符号。
中文的编码的范围,4e00 --9fa5
编码字符:\u4位16进制的数
chr(编码值)----获取编码值对应的字符。
ord(字符)---获取指定字符对应的编码值,返回的是十进制的。
:字符串在比较大小的时候比较的是编码值得大小,第一个大了那就是这个大不会再比较后面的。
注意:在python 中不同的进制之间也是可以比较大小的。
二。字符串的操作。
1.获取元素。
(1)获取单个元素
切片,遍历,字符串[下标]
一个空格是一个字符,按tab键是四个字符。
转义字符,\t对应一个字符
(2)切片:字符串[开始下标:结束下标:步长]
(3)直接遍历,通过下标遍历
(4)简洁的方法:
str="hello ,python"
for i in str:
print("i",i)
for index,item in enumerate(str):#这个方法可以获得元素和下标。
print(index,item)
(5)相关的操作:
1运算符:
加法---把两个字符串合并在一起产生一个新的字符串。原字符串不变,因为字符串不可变。
乘法---重复出现N次
比较大小:字符串1,字符串2
print("abcdf">"bc")
字符串比较大小比较的是字符串的编码值的大小。
print("Z">"a")
应用:
判断字母是否是小写字母:
"a"<=chr<="z"
判断字符是否是大写字母:
"A"<=chr<="Z"
判断是否是字母:
"A"<=char<"Z" or "a"<=chr()<="z"
判断字符是否是数字:"0"<=chr<="9"
练习,输入一个字符串,判断这个字符串是否是中文的字符串
str3=input("请输入字符串:")
for i in str3:
if 0x4e00<= ord(i) <= 0x9fa5:
print(i)
else:
print("输入错误")
a=hex(32)
b=oct(16)
print(hex(32)>oct(16))
str3 = input("请输入字符串:")
for i in str3:
if chr(0x4e00)<= i <= chr(0x9fa5):
print(i)
else:
print("输入错误")
value = input("请输入:")
for i in value:
if not "\u4e00 " <= i <= "9fa5" :
print("不是中文")
break
else:
print("中文")
(6)in not in 操作:
字符串1 in 字符串2 ---判断字符串2中是否包含字符串1
str2 = "abc123"
str4 = "abc"
print(str4 in str2),结果是True,
(7)相关的函数:len,str,sorted,reversed.
len(字符串)----判断字符串的长度,转义字符的长度是1.空格的长度要注意。
print("")---这个长度是0,print(" ")---这个是1
b.str(数据)---所有的数据都能转字符串。直接将原数据的打印值加引号。
c.sorted(字符串)----产生一个新的列表。按字符编码值排序的。(小--到)
srt="123adfsdfaSDFASDFASD"
print(sorted(str))
三.格式化字符串
字符--长度为1的字符串
格式字符串:
1.格式占位符:
a.语法:包含格式占位符的字符串 %(值1,值2,)
b.说明:
格式占位符:%s(字符串),%d(数字整型),%f(小数)
格式占位符使用的时候需根据类型来对应使用。
其实所有的数据都可以用%s来占位。
%-Nd--整数---可以来约束数字最后的长度,如果不够后面补空格。+,-数字N,,+在前面补空格,—后面补空格。
% .Nf-----N是约束小数点后的位数。
%f------这个一般不用,默认是保留六位小数。
本身是多少位就是多少,就用%s
%--固定写法 ()--固定写法,如果值是一个直接省略。 值--除了任何有结果的表达式,值得个数和类型和前面的占位符的个数以及类型保持一致。
%c----字符占位。可以把字符转为相应的数字
name = "xiaoma"
age = 18
money=234.5686868
print("我叫%s,我%6d岁,我有%.3f" % (name, age,money))
print("我叫%s,我%6d岁,我有%s" % (name, age,money))
.format
用法一:"...{ }".format(放进去)--几个大括号就放几个值。
print("我叫{},今年{}岁".format("马羽","18"))
用法二:{N} 从0开始依次增加,分别表示format中第0值第一个值,,,,
print("我是{0},今年{1}岁,我是{2}人").format("马羽","18","湖南")
用法三:[key]
"{key1},{key2}".format(key1=值1,key2=值2)
print("我是{name},年纪{age}".format(name="mau",age=18))
用法四:用列表的占位符赋值:
list=[10,20,34,56]
print("{0[0]},{0[1]},{0[2]}".format(list))
用法五:
student={"name":"小明","age":20}
print("{name}今年{age}岁".format(student))#解包
其他的写法:
print("圆周率:{:.2f}".format(3.1415926))
print("整数:{:0>4d}。".format(25))#大于前面加,下雨后面加 4个0
print("整数:{:+>4d}。".format(25))#大于前面加,下雨后面加 4个0
print("{:2%}".format(0.255))
四.字符串的相关的方法
1字符串.capitalize()--将字符串的首字母变成大写的字母。
大写字母和小写字母的差值是32
char="a"
print(chr(ord(char)-32))
2 字符串.center(宽度,填充字符)---原字符串在中间
字符串.ljust(宽度,填充字符)---原字符串在左边
字符串.rjust(宽度,填充字符)---原字符串在右边
字符串.zfill(宽度,填充字符)---用0 填充
str2="abc"
print(str2.center(7,"+"))
print(str2.ljust(7,"+"))
print(str2.rjust(7,"+"))
print(str2.zfill(7))
3字符串1.count(字符串2)---统计字符串1中字符串2出现的次数。
str1="what are you doing"
print(str1.count("a"))
4字符串1.count(字符串2,开始下标,结束下标)--在字符串1中统计字符串2从开始到结束出现的次数结尾取不到。
str1="what are you doing"
print(str1.count("a",0,3))
str3="abc"
str5="hao are you"#判断str3是否是str5的结尾
print(str5[-len(str3):]==str3)
5字符串1.index(查找的字符2),不存在会报错。
6字符串.find(需要查找的字符),不存在是-1
7字符串1.find(字符串2)--获取字符串2第一次在1出现的位置
8 字符串.join(序列)--将序列中的用字符串连在一起,序列中的元素必须是字符串。
字典使用这个方法拼接的是键。
print("+++++".join("abc"))#---前面决定用什么连接
print("+++++".join(["abc""cds"]))#---前面决定用什么连接
9. 字符串.maketrans(),字符串.translate()---字符串替换, 字符串1.replace(字符串2,字符串3)--将字符串1中所有的字符串2都替换成3
str1="what are you doing"
str0=str1.replace("you","me")
print(str0)
字符串1.translate(替换的映射表)
字符串2.maketrans(字符串3)--创建字符串2和字符串3对应的映射表
table=str.maketrans("a","的")#将字符串str1中的所有的a 替换成 的
new=str1.translate(table)
print(new)
10切割字符串
"""
字符串.split(字符串2)--将字符串1中的所有的字符串2作为切割点切成多份
"""
qie=str1.split("a")#--切割点不存在了
print(qie)
方法: