Python3.6字符串新特性

本文详细解析了Python中字符串前缀f、b、r、u的作用及应用实例,包括格式化字符串、bytes类型转换、原始字符串声明和Unicode编码,帮助读者深入理解并正确使用这些特性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

字符串前加 f

1、作用:
字符串格式化(python 3.6 新增,类似于变量内插赋值),格式化的字符串文字前缀为"f",类似str.format()。包含由花括号包围的替换区域。替换字段是表达式,在运行时进行评估,然后使用format()协议进行格式化。和之前的format字符串格式化差不多,但是用起来更简化

2、例子:

Python 3.6.5 
>>> var = "python3.6"
>>> print(f"这是{var}以上版本中的新特性")
这是python3.6以上版本中的新特性

python3.6以下的版本是没有这个特性的,下面以Python3.5.2 为例:

Python 3.5.2 
>>> var = "python3.6"
>>> print(f"这是{var}以上版本中的新特性")
  File "<stdin>", line 1
    print(f"这是{var}以上版本中的新特性")
                            ^
SyntaxError: invalid syntax


字符串前加 b

1、作用:
python3.x里默认的str(字符串)是unicode编码的。
b前缀代表的就是bytes ,就是把python3.x中的字符串类型转换成bytes类型。

python2.x里, 字符串就是bytes类型,因此b前缀没什么具体意义, 只是为了兼容python3.x的这种写法

Python的默认编码是ASCII编码,

2、例子:
在python3中:

Python 3.6.5 
>>> import hashlib
>>> m = hashlib.md5()
>>> m.update("hello world")
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
TypeError: Unicode-objects must be encoded before hashing # 错误信息提示必须编码
>>> m.update(b"hello world")
>>> m.digest()
b'^\xb6;\xbb\xe0\x1e\xee\xd0\x93\xcb"\xbb\x8fZ\xcd\xc3'
>>>

字符串前加 r

1、作用:
声明后面的字符串是普通字符串,相对的,特殊字符串中含有:转义字符 \n \t 什么什么的。这样转义符就会被当成普通的字符串,而不会起作用。
2、例子:

>>> print("hello world\n\n !")
hello world

 !
>>> print(r"hello world\n\n !")
hello world\n\n !

字符串前加 u

1、作用:
后面字符串以 Unicode 格式 进行编码,一般用在中文字符串前面,防止因为源码储存格式问题,导致再次使用时出现乱码。

2、例子:

u"哎呦,不错!"
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值