位数少的转换成位数多的,直接赋值就好了,比如8位的整数24转换成32位还是24。
而位数多的转换成位数少的是截取低位那么多位数,比如32位的整数257,其二进制是1 0000 0001,转换成8位时,就截取后面的8位,即0000 0001,所以32位的整数257转换成8位的整数时等于1。
32位的整数a转换成16位整数b,b = a & 0xFFFF
32位的整数a转换成8位整数b,b = a & 0xFF
a = np.array([257])
b = a.astype(np.uint8)
b
>>array([1], dtype=uint8)
32位转8位的数值相当于a & 0xFF,这只是对32位整数做与运算,并没有改变其位数
>>array([1], dtype=int32)