鱼C论坛

 找回密码
 立即注册
查看: 1714|回复: 2

[已解决]python字符串问题

[复制链接]
发表于 2020-10-19 09:46:56 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
之前只知道在字符串之前加个r表示原始字符串,今天学jango的时候又碰见个加b的,想问问大家这种处理字符串格式的一共有多少啊,翻了翻论坛好像没有找到,有知道的给个链接叭
最佳答案
2020-10-19 10:13:07
我了解到的字符串前缀有b, u, r, f。
b是bytes类型,可以和string类型相互转换
>>> b = b'ABC'
>>> s = 'ABC'
>>> type(b)
<class 'bytes'>
>>> type(s)
<class 'str'>
>>> b2s = b.decode()
>>> s2b = s.encode()
>>> b2s
'ABC'
>>> s2b
b'ABC'

u是表示以 Unicode 格式 进行编码,再python3一般不用特别指明
>>> u = u'中文'
>>> u
'中文'

f是f-string,是格式化字符串的一种方式。
>>> age = 23
>>> f = f'年龄是:{age}岁'
>>> f
'年龄是:23岁'
以上前缀字符大小写都可以。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-10-19 09:56:40 From FishC Mobile | 显示全部楼层
本帖最后由 hrp 于 2020-10-19 10:10 编辑

类似b'abc'这样的是字节对象,不是字符串。
字节对象先解码,得到的才是字符串:
b'abc'.decode('utf-8')
# 'abc'
字符串进行编码,得到字节对象:
'abc你好'.encode('utf-8')
# b'abc\xe4\xbd\xa0\xe5\xa5\xbd'

交互模式显示结果:
>>> b'abc'.decode('utf-8')
'abc'
>>> 'abc你好'.encode('utf-8')
b'abc\xe4\xbd\xa0\xe5\xa5\xbd'
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-10-19 10:13:07 | 显示全部楼层    本楼为最佳答案   
我了解到的字符串前缀有b, u, r, f。
b是bytes类型,可以和string类型相互转换
>>> b = b'ABC'
>>> s = 'ABC'
>>> type(b)
<class 'bytes'>
>>> type(s)
<class 'str'>
>>> b2s = b.decode()
>>> s2b = s.encode()
>>> b2s
'ABC'
>>> s2b
b'ABC'

u是表示以 Unicode 格式 进行编码,再python3一般不用特别指明
>>> u = u'中文'
>>> u
'中文'

f是f-string,是格式化字符串的一种方式。
>>> age = 23
>>> f = f'年龄是:{age}岁'
>>> f
'年龄是:23岁'
以上前缀字符大小写都可以。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-18 07:28

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表