返回顶部
首页 > 资讯 > 后端开发 > Python >如何修改numpy array的数据类型
  • 694
分享到

如何修改numpy array的数据类型

2024-04-02 19:04:59 694人浏览 八月长安

Python 官方文档:入门教程 => 点击学习

摘要

目录修改numpy array数据类型1、numpy数据类型2、改变numpy array数据类型numpy数据类型说明及自动转换陷阱1、数据类型的表示2、构造ndarray时的dt

修改numpy array数据类型

1、numpy数据类型

数据名称说明
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 位浮点数(实数部分和虚数部分)

2、改变numpy array数据类型

用astype()方法改变数据类型,如下几种方式所示(这种方法不会改变原数组的数据类型):

array_name.astype(int)  
array_name.astype(np.int16)
array_name.astype('float64')

如果要改变原数组的数据类型,用以下方法:

array_name.dtype = np.uint8

numpy数据类型说明及自动转换陷阱

numpy的dtype是一个很重要的概念,因为numpy为了性能,优化了内存管理,ndarray的值在内存中几乎是连续的,同时其每个元素的内存大小也被设计成是一样的,因此,当生成ndarray时,每个元素的数据类型都会被转为相同的类型,这时如果原生的数据类型是不一样的,那么就涉及到一个数据类型转换的问题,即data type casting。

明白numpy中的数据类型转换可以有效的避免和理解很多的行为,因为numpy中很多的error往往都是有数据类型转换引起的,所以理解numpy的数据类型转换可以预防和排查很多的问题。首先,在numpy中有很多的数据类型,多于Python内置数据类型,具体有哪些类型,可以参看下图,下图的columns和index是数据类型在numpy中的符号,具体的释义可以查看这里。下面,我们重点讲一下numpy中关于数据类型以及转换中容易碰到的陷进或者需要注意的点。

1、数据类型的表示

在numpy中,一个数据类型实际上是一个dtype对象,其有一些重要的属性,比如字节顺序、数据类型、字节数大小等,一般的,numpy中的数据类型会表示成类似'<i4'这样,这个表示法中,<表示字节顺序,i表示数据类型,这里表示整数,4表示一个元素占据的字节数,这里4字节,表示32位整数。

2、构造ndarray时的dtype

在构造ndarray时,可以指定dtype参数来设置ndarray里面元素的数据类型,这个dtype可以用'i4'这样的表示方式,也可以用int表示,但是后者没法指定字节数。要注意的是,指定dtype时,一定要确认这个dtype可以兼容所有元素,防止溢出或者不兼容,对此我们可以通过result_type(*array_like)来判断我们应该设定的dtype,这个函数返回的dtype是可以兼容所有元素的最小size的数据类型;或者我们无需设定,其会自动进行数据类型的转换,我们也可以通过ndarray.dtype属性查看数据类型。Anyway,我们要有这种数据类型转换的意识,因为这会影响后续对ndarray的操作。

3、不同数据类型之间的转换兼容性

 numpy的数据类型之间能够实现转换,可以通过np.can_cast(fromtype,totype)这个函数来判断,更详细的可以查看下图。

4、numpy对python对象数据类型'O'的处理

 当numpy中有python独有的原生数据类型,比如Decimal,那么ndarray会被转为object数据类型,表示python对象数据类型,当然这里也可以转为字符串,但是字符串对于np.nan往往会占据更大的itemsize。

当numpy函数对dtype位object的ndarray处理时,会先把里面的元素再进一步转为其他numpy的数据类型,这样才可以操作,所以这里如果函数没法或没有指定类型参数,那么会默认以第一个inner loop到的数据类型作为所有元素的类型,并以此类型进行后续转换,这时,对于object类型的ndarray来说,往往容易出现数据无法转换成功的异常。所以要注意处理时第一个inner loop遇到的元素的类型是否可以兼容后面要处理的所有元素,不然会抛出异常。看下面的例子说明。

import numpy as np
from decimal import Decimal
 
arr=np.array([[1,2.0,3],['a',3,np.nan],[2,np.nan,Decimal('5')]])
arr1=np.apply_along_axis(lambda x:x[0],arr=arr,axis=1)
arr1
# output:
# ValueError: invalid literal for int() with base 10: 'a'
 
arr2=np.apply_along_axis(lambda x:x[1],arr=arr,axis=1)
arr2
# output:
# array([ 2.,  3., nan])
 
arr2=np.apply_along_axis(lambda x:x[2],arr=arr,axis=1)
arr2
# output:
# array([          3, -2147483648,           5])

从上面的例子中可以看到,arr1中,由于第一个inner loop遇到的元素是整数1,所以便会以整数类型对后续的元素进行转换,但是后面的一个元素是字符'a',无法将其转为int,因此就会报上述error;arr2中,第一个遇到的元素是2.0,为float,所以后面的元素都会被转为float,因此输出为array([ 2.,  3., nan]),其中都变成了float,要注意的是,由于np.nan本身就是一个浮点数,因此这里可以正确的转换,转换之后还是np.nan;但是看arr2,由于第一个遇到的元素类型为int32,后面的np.nan为float64,会造成溢出,这样便无法正确的转换,从而会用int32最接近np.nan的值去替换,所以就是-2**31==-2147483648,这里之所以是2**31,而不是2**32-1,是因为这里的int是signed int,即有正负号的int,所以其范围是-2**31~2**31-1;而Decimal('5')被转为了int 5,所以就出现了上述的结果。

 所以,当要被转成ndarray的原始数据中有np.nan时,要特别注意这一点,最好是指定float类型,注意其他数据的兼容;而如果同时又是obejct数据类型时,那么同时也要注意第一个inner loop遇到的元素的数据类型,注意和后面的数据类型保持兼容。

小结:numpy的dtype有诸多陷进,需要小心对待,谨慎核查,然后灵活运用。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

--结束END--

本文标题: 如何修改numpy array的数据类型

本文链接: https://lsjlt.com/news/118089.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 如何修改numpy array的数据类型
    目录修改numpy array数据类型1、numpy数据类型2、改变numpy array数据类型numpy数据类型说明及自动转换陷阱1、数据类型的表示2、构造ndarray时的dt...
    99+
    2024-04-02
  • sqlserver如何修改数据类型
    要修改数据库中表的数据类型,可以使用ALTER TABLE语句来修改数据类型。以下是一个例子: ALTER TABLE 表名 ALT...
    99+
    2024-04-12
    sqlserver
  • oracle如何修改列的数据类型
    要修改Oracle表的列数据类型,需要使用ALTER TABLE语句。以下是一些示例: 修改列的数据类型: ALTER TABL...
    99+
    2024-04-15
    oracle
  • 如何修改mysql列数据类型
    这篇文章主要介绍了如何修改mysql列数据类型,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让小编带着大家一起了解一下。怎样修改mysql列数据类型的方法:通过“ALTER...
    99+
    2024-04-02
  • mysql如何修改name数据类型
    要修改mysql中name字段的数据类型,可以使用ALTER TABLE语句进行修改。以下是修改name字段数据类型的示例: ALT...
    99+
    2024-04-09
    mysql
  • sql如何修改表列的数据类型
    要修改表列的数据类型,可以使用ALTER TABLE语句。例如,要将表中的某一列的数据类型从INT改为VARCHAR,可以使用以下语...
    99+
    2024-04-09
    sql
  • mysql如何修改字段数据类型
    要修改MySQL表中的字段数据类型,可以使用ALTER TABLE语句。下面是修改字段数据类型的示例:```ALTER TABLE ...
    99+
    2023-08-25
    mysql
  • php如何修改数据表的字段类型
    这篇文章主要介绍“php如何修改数据表的字段类型”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“php如何修改数据表的字段类型”文章能帮助大家解决问题。在 PHP 中,修改数据表的字段类型是一项非常重...
    99+
    2023-07-05
  • mysql如何修改表中列的数据类型
    要修改表中列的数据类型,可以使用 ALTER TABLE 语句来实现。以下是修改列数据类型的示例: ALTER TABLE 表名 M...
    99+
    2024-04-22
    mysql
  • mysql数据库中如何修改表类型
    这篇文章主要介绍mysql数据库中如何修改表类型,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完! 在mysql中,可以利用“alter table”语句和“...
    99+
    2024-04-02
  • PHP中array复合数据类型如何使用
    PHP中array复合数据类型如何使用,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。(1), array(数组) :PHP 中的数组实际上是把一个优化过的有序图类型当成数组来使...
    99+
    2023-06-17
  • oracle如何修改数据库表字段类型
    您可以使用ALTER TABLE语句来修改Oracle数据库表的字段类型。下面是一个例子:```sqlALTER TABLE 表名 ...
    99+
    2023-09-05
    oracle 数据库
  • php如何改变数据类型
    这篇文章给大家分享的是有关php如何改变数据类型的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。php的框架有哪些php的框架:1、Laravel,Laravel是一款免费并且开源的PHP应用框架。2、Phalco...
    99+
    2023-06-15
  • 如何在PHP中处理NumPy类型的数据?
    在PHP中处理NumPy类型的数据是一个常见的需求,因为NumPy是一个广泛使用的Python库,常用于科学计算、数据分析和机器学习等领域。本文将介绍如何在PHP中处理NumPy类型的数据。 NumPy数据类型 在了解如何处理NumPy...
    99+
    2023-06-29
    数据类型 实时 numy
  • mysql如何修改表的类型
    这篇文章主要介绍“mysql如何修改表的类型”,在日常操作中,相信很多人在mysql如何修改表的类型问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”mysql如何修改表的类型”...
    99+
    2024-04-02
  • oracle怎么修改列的数据类型
    要修改列的数据类型,可以使用ALTER TABLE语句。下面是一个示例: ALTER TABLE table_name MODIFY...
    99+
    2024-04-22
    oracle
  • mysql怎么修改表的数据类型
    要修改MySQL表的数据类型,可以使用ALTER TABLE语句并指定MODIFY COLUMN子句来更改列的数据类型。 例如,要将...
    99+
    2024-04-22
    mysql
  • 如何在 PHP 中存储 NumPy 数据类型?
    在 PHP 中存储 NumPy 数据类型是一个常见的需求,因为 NumPy 提供了很多高效的数学运算和数据处理功能,而 PHP 是一种常用的服务器端编程语言,它可以方便地与 Web 应用程序集成。在本文中,我们将介绍如何在 PHP 中存储 ...
    99+
    2023-10-02
    数据类型 存储 numpy
  • 如何在Go中使用NumPy数据类型?
    NumPy是一个Python科学计算库,它提供了一种多维数组对象和一系列的操作数组的函数。它还提供了线性代数、傅里叶变换和随机数生成等功能。虽然NumPy是用Python编写的,但是它的一些基本数据类型可以在其他语言中使用。Go是一种快速...
    99+
    2023-07-19
    numy laravel 数据类型
  • 如何在Laravel中使用NumPy数据类型?
    Laravel是一款流行的PHP框架,它提供了丰富的工具和组件来帮助开发者构建高效、可靠的Web应用程序。NumPy是一款Python科学计算库,它提供了许多高级的数据类型和函数,可以帮助处理大规模数据集。在本文中,我们将介绍如何在Lara...
    99+
    2023-07-19
    numy laravel 数据类型
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作