Python入门8(字符串)

一、字符串的驻留机制

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'

注意:编码和解码的字符集必须相同

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值