python字符串前的a前缀是什么意思?

2020/12/01 00:51 · python ·  · 0评论

在python源代码中,我偶然发现在类似如下的字符串之前看到一个小b

b"abcdef"

我知道u表示unicode字符串的r前缀和原始字符串文字前缀。

b它看起来像完全没有任何前缀的纯字符串,它代表什么?它在哪种源代码中有用?

这是Python3bytes 文字在Python 2.5和更早版本中不存在此前缀(它等效于2.x的纯字符串,而3.x的纯字符串等效u于2.x中前缀的文字)。在Python 2.6+中,它等效于纯字符串,以与3.x兼容

b前缀表示一个bytes字符串常量

如果您看到它在Python 3源代码中使用过,该表达式将创建一个bytes对象,而不是常规Unicodestr对象如果您看到它在Python Shell中回显,或者作为列表,字典或其他容器内容的一部分回显,那么您会看到bytes使用此符号表示对象。

bytes对象基本上包含一个介于0到255之间的整数序列,但是当表示这些对象时,Python会将这些字节显示为ASCII码点,以便于读取其内容。外部任何字节可打印的ASCII字符范围被示为转义序列(例如\n\x82等)。相反,您可以同时使用ASCII字符和转义序列来定义字节值。对于ASCII值,使用其数字值(例如b'A'== b'\x41'

由于bytes对象由整数序列组成,因此您可以使用bytes其他任何整数序列(其值在0-255范围内)构造对象,例如列表:

bytes([72, 101, 108, 108, 111])

和索引会给您返回整数(但切片会产生一个新bytes值;对于上面的示例,value[0]给您72,但是value[:1]是,b'H'因为72是大写字母H的ASCII代码点)。

bytes模拟二进制数据,包括编码文本如果您的bytes值确实包含文本,则需要先使用正确的编解码器对其进行解码。例如,如果数据编码为UTF-8,则可以使用以下方法获取Unicodestr值:

strvalue = bytesvalue.decode('utf-8')

相反,要从str对象中的文本转到bytes需要编码您需要确定要使用的编码。默认是使用UTF-8,但是您所需要的很大程度上取决于您的用例:

bytesvalue = strvalue.encode('utf-8')

您也可以使用构造函数bytes(strvalue, encoding)执行相同的操作。

解码和编码方法都使用一个额外的参数来指定应如何处理错误

Python 2版本2.6和2.7还支持使用b'..'字符串文字语法创建字符串文字,以简化适用于Python 2和3的代码。

bytes对象是不变的,就像str字符串一样。如果您需要一个可变的字节值,请使用一个bytearray()对象

本文地址:http://python.askforanswer.com/pythonzifuchuanqiandeaqianzhuishishenmeyisi.html
文章标签: ,   ,   ,  
版权声明:本文为原创文章,版权归 admin 所有,欢迎分享本文,转载请保留出处!

文件下载

老薛主机终身7折优惠码boke112

上一篇:
下一篇:

评论已关闭!