binascii —- 二进制和 ASCII 码互转
binascii
模块包含很多在二进制和二进制表示的各种ASCII码之间转换的方法。 通常情况不会直接使用这些函数,而是使用像 uu
, base64
,或 binhex
这样的封装模块。 为了执行效率高,binascii
模块含有许多用 C 写的低级函数,这些底层函数被一些高级模块所使用。
注解
a2b_*
函数接受只含有 ASCII 码的Unicode 字符串。其他函数只接受 字节类对象 (例如 bytes
,bytearray
和其他支持缓冲区协议的对象)。
在 3.3 版更改: ASCII-only unicode strings are now accepted by the a2b_*
functions.
binascii
模块定义了以下函数:
binascii.
b2auu
(_data, *, backtick=False)- 将二进制数据转换为 ASCII 编码字符,返回值是转换后的行数据,包括换行符。 data 的长度最多为45。如果 backtick 为ture,则零由
'`'
而不是空格表示。
在 3.7 版更改: 增加 backtick 形参。
binascii.
b2abase64
(_data, *, newline=True)- 将二进制数据转换为一行用 base64 编码的ASCII字符串。返回值是转换后的行数据,如果 newline 为true,则返回值包括换行符。该函数的输出符合:rfc:3548。
在 3.6 版更改: 增加 newline 形参。
binascii.
a2bqp
(_data, header=False)- 将一个引号可打印的数据块转换成二进制数据并返回。一次可以转换多行。如果可选参数 header 存在且为true,则数据中的下划线将被解码成空格。
binascii.
b2aqp
(_data, quotetabs=False, istext=True, header=False)- 将二进制数据转换为一行或多行带引号可打印编码的ASCII字符串。返回值是转换后的行数据。如果可选参数 quotetabs 存在且为真值,则对所有制表符和空格进行编码。如果可选参数 istext 存在且为真值,则不对新行进行编码,但将对尾随空格进行编码。如果可选参数 header 存在且为true,则空格将被编码为下划线 RFC 1522。如果可选参数 header 存在且为假值,则也会对换行符进行编码;不进行换行转换编码可能会破坏二进制数据流。
binascii.
a2bhqx
(_string)- 将 binhex4 格式的 ASCII 数据不进行 RLE 解压缩直接转换为二进制数据。该字符串应包含完整数量的二进制字节,或者(在binhex4 数据最后部分)剩余位为零。
binascii.
rledecodehqx
(_data)- 根据 binhex4 标准对数据执行 RLE 解压缩。该算法在一个字节的数据后使用
0x90
作为重复指示符,然后计数。计数0
指定字节值0x90
。该例程返回解压缩的数据,输入数据以孤立的重复指示符结束的情况下,将引发Incomplete
异常。
在 3.2 版更改: 仅接受 bytestring 或 bytearray 对象作为输入。
binascii.
crchqx
(_data, value)- 以 value 作为初始 CRC 计算 data 的16位 CRC 值,返回其结果。这里使用 CRC-CCITT 生成多项式 _x_16 + _x_12 + _x_5 + 1 ,通常表示为0x1021。该 CRC 被用于 binhex4 格式。
binascii.
crc32
(data[, value])- 计算 CRC-32 ,从 value 的初始 CRC 开始计算 data 的32位校验和。默认初始 CRC 为零。该算法与 ZIP 文件校验和一致。由于该算法被设计用作校验和算法,因此不适合用作通用散列算法。使用方法如下:
- print(binascii.crc32(b"hello world"))
- # Or, in two pieces:
- crc = binascii.crc32(b"hello")
- crc = binascii.crc32(b" world", crc)
- print('crc32 = {:#010x}'.format(crc))
在 3.0 版更改: 校验结果始终是无符号类型的。要在所有Python版本和平台上生成相同的数值,请使用 crc32(data) & 0xffffffff
。
binascii.
b2ahex
(_data)binascii.
hexlify
(data)- 返回二进制数据 data 的十六进制表示形式。 data 的每个字节都被转换为相应的2位十六进制表示形式。因此返回的字节对象的长度是 data 的两倍。
使用:bytes.hex()
方法也可以方便地实现相似的功能(但仅返回文本字符串)。
binascii.
a2bhex
(_hexstr)binascii.
unhexlify
(hexstr)- 返回由十六进制字符串 hexstr 表示的二进制数据。此函数功能与
b2a_hex()
相反。 hexstr 必须包含偶数个十六进制数字(可以是大写或小写),否则会引发Error
异常。
使用:bytes.fromhex()
类方法也实现相似的功能(仅接受文本字符串参数,不限制其中的空白字符)。
参见