首先要明确一点,在计算机中存储的只有二进制数据,无论它是有符号还是无符号、是int还是str,都是计算机的使用者的主观意识。因此对于任何数据类型,我们都可以得到它在计算机中的真实状态。
1、int类型转byte类型:
我们都知道,在python中是没有具体的int类型的,python并没有规定int类型的长度,官方给出的回答是 Integers have unlimited precision(整数具有无限精度),因此在此类转换中我们要自己规定转换结束后得到几个字节。
在此,我们用到了to_bytes()函数,函数有三个参数,分别是length,byteorder和signed:
length参数规定函数返回的字节数;
byteorder规定数组的排列方式,‘big’表示大的在前,符合我们的阅读习惯,‘little’代表大的在后;
signed参数告诉计算机这个数字是否是有符号数,‘TRUE’表示是有符号数,‘false’表示不是,对于正数来说这个参数无所谓。
以下是python3.5官方文档的给出的示例。
同样,如果我们想把字节数组转换为int类型可以使用from_bytes()函数。
2、float类型与int类型
float.
as_integer_ratio
()
该函数返回一个分数,分数的小数形式与原始float型变量相同。但是不是最简形式。
float.
hex
()¶和float.formhex()函数分别将float类型转换为相应的十六进制字符串和将十六进制字符串转化成float类型。
3、str类型与bytes类型
字符串有多种编码方法,如ASCII码、扩展的ASCII码、Unicode编码、UTF-8编码、GBK编码等,它们的用处不同,长度也不同、因此同样的bytes不同的编码方法会得出不同的结果。所以在实现str类型的bytes类型转换时要明确编码和解码方式。
str.encode()函数用来将str转化为bytes数组:默认编码方式为utf-8,如有需要应在函数中以参数形式告知。
bytes.decode()函数将bytes转化为相应编码形式的数据。