02-python-numpy-datatype
2. NumPy之:数据类型
简介
我们知道Python中有4种数字类型,分别是int,float,bool和complex。作为科学计算的NumPy,其数据类型更加的丰富。
今天给大家详细讲解一下NumPy中的数据类型。
数组中的数据类型
NumPy是用C语言来实现的,我们可以对标一下NumPy中数组中的数据类型跟C语言中的数据类型:
Numpy 中的类型 | C 中的类型 | 说明 |
---|---|---|
np.bool_ |
| Boolean (True or False) stored as a byte |
np.byte |
| Platform-defined |
np.ubyte |
| Platform-defined |
np.short |
| Platform-defined |
np.ushort |
| Platform-defined |
np.intc |
| Platform-defined |
np.uintc |
| Platform-defined |
np.int_ |
| Platform-defined |
np.uint |
| Platform-defined |
np.longlong |
| Platform-defined |
np.ulonglong |
| Platform-defined |
np.half / np.float16 | Half precision float: sign bit, 5 bits exponent, 10 bits mantissa | |
np.single |
| Platform-defined single precision float: typically sign bit, 8 bits exponent, 23 bits mantissa |
np.double |
| Platform-defined double precision float: typically sign bit, 11 bits exponent, 52 bits mantissa. |
np.longdouble |
| Platform-defined extended-precision float |
np.csingle |
| Complex number, represented by two single-precision floats (real and imaginary components) |
np.cdouble |
| Complex number, represented by two double-precision floats (real and imaginary components). |
np.clongdouble |
| Complex number, represented by two extended-precision floats (real and imaginary components). |
我们在Ipython环境中随机查看一下上面的类型到底是什么:
所以上面的数据类型,其底层还是固定长度的数据类型,我们看下到底有哪些:
Numpy 类型 | C 类型 | 说明 |
---|---|---|
np.int8 |
| Byte (-128 to 127) |
np.int16 |
| Integer (-32768 to 32767) |
np.int32 |
| Integer (-2147483648 to 2147483647) |
np.int64 |
| Integer (-9223372036854775808 to 9223372036854775807) |
np.uint8 |
| Unsigned integer (0 to 255) |
np.uint16 |
| Unsigned integer (0 to 65535) |
np.uint32 |
| Unsigned integer (0 to 4294967295) |
np.uint64 |
| Unsigned integer (0 to 18446744073709551615) |
np.intp |
| Integer used for indexing, typically the same as |
np.uintp |
| Integer large enough to hold a pointer |
np.float32 |
| |
np.float64 / np.float_ |
| Note that this matches the precision of the builtin python float. |
np.complex64 |
| Complex number, represented by two 32-bit floats (real and imaginary components) |
np.complex128 / np.complex_ |
| Note that this matches the precision of the builtin python complex. |
所有这些类型都是 dtype 对象的实例。常用的有5种基本类型,分别是bool,int,uint,float和complex。
类型后面带的数字表示的是该类型所占的字节数。
上面表格中有一些 Platform-defined的数据类型,这些类型是跟平台相关的,在使用的时候要特别注意。
这些dtype类型可以在创建数组的时候手动指定:
由于历史原因,为了向下兼容,我们也可以在创建数组的时候指定字符格式的dtype。
上面的 f 表示的是float类型。
类型转换
如果想要转换一个现有的数组类型,可以使用数组自带的astype方法,也可以调用np的强制转换方法:
注意,上面我们使用了 float , Python将会把float 自动替换成为 np.float_,同样的简化格式还有
int
==np.int_
,bool
==np.bool_
,complex
==np.complex_
. 其他的数据类型不能使用简化版本。
查看类型
查看一个数组的数据类型可以使用自带的dtype属性:
dtype作为一个对象,本身也可以进行一些类型判断操作:
数据溢出
一般来说,如果超出了数据的范围是会报异常的。比如我们有一个非常长的int值:
上面的数字太长了,超出了int32的范围,就会抛出异常。
但是NumPy的有些操作,如果超出范围之后,并不会报异常,而是正常范围,这时候我们就需要注意了:
NumPy提供了两个方法来测量int和float的范围,numpy.iinfo 和 numpy.finfo :
如果64位的int还是太小的话,可以使用np.float64,float64可以使用科学计数法,所以能够得到更大范围的结果,但是其精度可能会缩小。
本文已收录于 www.flydean.com
最通俗的解读,最深刻的干货,最简洁的教程,众多你不知道的小技巧等你来发现!
欢迎关注我的公众号:「程序那些事」,懂技术,更懂你!
最后更新于