一、字符串的驻留机制
1、概述
举例:
a='python'
b="python"
c='''python'''
print(a,id(a))
print(a,id(b))
print(a,id(c))
结果如下:
2、驻留机制的四种情况(交互模式下,而PyCharm对其进行了优化)
举例1:
举例2:关于字符串在编译期间驻留,而非运行时
上图b的字符连接发生在程序运行之前,而c中join函数的调用运行是在程序运行之后。
2、强制驻留
举例3:
3、驻留优缺点
二、字符串的查询
举例
三、字符串大小写转换
举例:
四、字符串内容对齐操作
举例:
a='helloworld'
b='-41280'
print(a.center(20,'*'))
print(a.ljust(20,'*'))
print(a.rjust(20,'*'))
print(a.zfill(20))
#下面较特殊
print(b.zfill(20))
结果如下:
五、字符串劈分操作
举例:
a='hello world python'
lst=a.split()
print(lst,type(lst))
a='hello|world|python'
lst=a.split(sep='|')
print(lst)
lst=a.split(sep='|',maxsplit=1)
print(lst)
print("--------------------------------------------")
a='hello world python'
lst=a.rsplit()
print(lst,type(lst))
a='hello|world|python'
lst=a.rsplit(sep='|')
print(lst)
lst=a.rsplit(sep='|',maxsplit=1)
print(lst)
结果如下:
六、判断字符串操作的方法
举例:
七、字符串的替换与合并
a='hello,python python python python'
#替换
print(a.replace('python','java'))
print(a.replace('python','java',2))
#合并
lst=['hello','world','python']
print('|'.join(lst))
print(''.join(lst))
tup=('hello','world','python')
print('|'.join(tup))
print(''.join(tup))
print('*'.join("python"))
结果如下:
八、字符串的比较操作
举例:
m='apple'
n='bnana'
print(m>n) #False
print(ord('a'),ord('b')) #97 98
print(chr(97),chr(98)) #a b
注意:==与is的区别在于,==比较的是value,而is比较的是id。
九、字符串的切片操作
举例:
str='hello,Python'
str1=str[:5]
str2=str[6:]
str3='!='
new_str=str1+str3+str2
print(new_str) #hello!=Python
print("-------------------id地址-----------------")
print(id(str)) # 2884481547888
print(id(str1)) # 2884481600048
print(id(str2)) # 2884481779504
print(id(str3)) # 2884481555760
print(id(new_str)) # 2884481780080
#字符串切片规则与列表一致:切片[start:stop:step]
十、格式化字符串
1、引入话题
2、格式化字符串的方法
举例:
name='张三'
age=18
# 1、%占位符
print("我叫%s,今年%d岁了" % (name,age)) # 我叫张三,今年18岁了
# 2、{}
print("我叫{0},今年{1}岁了".format(name,age)) # 我叫张三,今年18岁了
# 3、f-string
print(f"我叫{name},今年{age}岁了") # 我叫张三,今年18岁了
#------------------------关于%精度设置(与c语言类似)----------------------------------------------
print('%d' % 99) #字符串没有宽度
print('%10d' % 99) #10表示宽度
print('%.4f' % 3.1415296) #.4表示小数点后三位
print('%10.3f' % 3.1415296) #宽度+小数点后三位
#------------------------关于{}精度设置------------------------------------------------------------
print("{}".format(3.1415926)) #{}内不加标识也可以 3.1415926
print("{0}".format(3.1415926)) # 3.1415926
print("{0:.3}".format(3.1415925)) #.3表示一共只有3位数 3.14
print("{0:.3f}".format(3.1415925)) #.3f表示保留3位小数
print("{0:10.3f}".format(3.1415925)) #表示一共10位,其中三位是小数
十一、字符串的编码与解码
1、话题引入
s='斗破苍穹'
print(s.encode(encoding='GBK')) #在GBK编码格式中,一个中文占两个字节
print(s.encode(encoding='UTF-8')) #在GBK编码格式中,一个中文占三个字节
byte=s.encode(encoding='GBK') #编码
print(byte.decode(encoding='GBK')) #解码
byte=s.encode(encoding='UTF-8') #编码
print(byte.decode(encoding='UTF-8')) #解码
#结果
b'\xb6\xb7\xc6\xc6\xb2\xd4\xf1\xb7'
b'\xe6\x96\x97\xe7\xa0\xb4\xe8\x8b\x8d\xe7\xa9\xb9'
注意:编码和解码的字符集必须相同