NumPy-ndarray 的数据类型

ndarray 的数据类型

数据类型,即 dtype ,也是一个特殊的对象, 它包含了ndarray须要为某一种类型数据所申明的内存块信息(也成为了元数据,即表示数据的数据)python

dtype是NumPy可以与琪他系统数据灵活交互的缘由。一般,其余系统提供一个硬盘或内存与数据的对应关系,使得利用C或Fortran等底层语言读写数据变得十分方便。数组

名称 描述
bool_ 布尔型数据类型(True 或者 False)
int_ 默认的整数类型(相似于 C 语言中的 long,int32 或 int64)
intc 与 C 的 int 类型同样,通常是 int32 或 int 64
intp 用于索引的整数类型(相似于 C 的 ssize_t,通常状况下仍然是 int32 或 int64)
int8 字节(-128 to 127)
int16 整数(-32768 to 32767)
int32 整数(-2147483648 to 2147483647)
int64 整数(-9223372036854775808 to 9223372036854775807)
uint8 无符号整数(0 to 255)
uint16 无符号整数(0 to 65535)
uint32 无符号整数(0 to 4294967295)
uint64 无符号整数(0 to 18446744073709551615)
float_ float64 类型的简写
float16 半精度浮点数,包括:1 个符号位,5 个指数位,10 个尾数位
float32 单精度浮点数,包括:1 个符号位,8 个指数位,23 个尾数位
float64 双精度浮点数,包括:1 个符号位,11 个指数位,52 个尾数位
complex_ complex128 类型的简写,即 128 位复数
complex64 复数,表示双 32 位浮点数(实数部分和虚数部分)
complex128 复数,表示双 64 位浮点数(实数部分和虚数部分)

使用astype方法来显式的转换数组的数据类型ui

arr = np.array([1,2,3,4,5])
print(arr.dtype)
print(arr)
float_arr = arr.astype('float32')#也能够写做 arr.astype(np.float32)
print(float_arr.dtype)
print(float_arr)

int32 [1 2 3 4 5] float32 [1. 2. 3. 4. 5.]spa

注意:将内容为数字的字符串数组转为数字是能够的,当内容是浮点型数字的时候只能转成 float,不能 int,只有是整数的时候才能够转成intcode

用其余数组的dtype来转换数据类型:对象

int_arr = np.arange(10)
calibers = np.array([.22, .270, .357], dtype=np.float64)
print(calibers)
arr_last = int_arr.astype(calibers.dtype)
print(arr_last.dtype)
print(arr_last)

[0.22 0.27 0.357] float64 [0. 1. 2. 3. 4. 5. 6. 7. 8. 9.]索引

相关文章
相关标签/搜索