numpy.binary_repr#
- numpy.binary_repr(num, width=None)[source]#
以字符串形式返回输入数字的二进制表示。
对于负数,如果未给出宽度,则在前面添加一个负号。如果给定宽度,则返回该数字的二进制补码,其位数与指定宽度相符。
在二进制补码系统中,负数由其绝对值的二进制补码表示。这是计算机上表示带符号整数最常用的方法 [1]。N 位二进制补码系统可以表示范围从 \(-2^{N-1}\) 到 \(+2^{N-1}-1\) 的所有整数。
- 参数:
- numint
只能使用整数十进制数。
- widthint, 可选
如果 num 为正数,则为返回字符串的长度;如果 num 为负数,则为二进制补码的长度,前提是 width 至少足以表示 num 为指定形式的位数。如果 width 值不足,则会引发错误。
- 返回:
- binstr
num 的二进制表示或 num 的二进制补码。
备注
binary_repr
等同于使用base_repr
并以 2 为基数,但速度快约 25 倍。参考文献
[1]维基百科,“二进制补码”,https://en.wikipedia.org/wiki/Two’s_complement
示例
>>> import numpy as np >>> np.binary_repr(3) '11' >>> np.binary_repr(-3) '-11' >>> np.binary_repr(3, width=4) '0011'
当输入数字为负且指定宽度时,将返回二进制补码。
>>> np.binary_repr(-3, width=3) '101' >>> np.binary_repr(-3, width=5) '11101'