文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

numpy数据类型dtype转换实现的示例

2023-06-14 19:33

关注

小编给大家分享一下numpy数据类型dtype转换实现的示例,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

导入numpy

>>> import numpy as np

一、随便玩玩

生成一个浮点数组

>>> a = np.random.random(4)

看看信息

>>> aarray([ 0.0945377 ,  0.52199916,  0.62490646,  0.21260126])>>> a.dtypedtype('float64')>>> a.shape(4,)

改变dtype,发现数组长度翻倍!

>>> a.dtype = 'float32'>>> aarray([  3.65532693e+20,   1.43907535e+00,  -3.31994873e-25,         1.75549972e+00,  -2.75686653e+14,   1.78122652e+00,        -1.03207532e-19,   1.58760118e+00], dtype=float32)>>> a.shape(8,)

改变dtype,数组长度再次翻倍!

>>> a.dtype = 'float16'>>> aarray([ -9.58442688e-05,   7.19000000e+02,   2.38159180e-01,         1.92968750e+00,              nan,  -1.66034698e-03,        -2.63427734e-01,   1.96875000e+00,  -1.07519531e+00,        -1.19625000e+02,              nan,   1.97167969e+00,        -1.60156250e-01,  -7.76290894e-03,   4.07226562e-01,         1.94824219e+00], dtype=float16)>>> a.shape(16,)

改变dtype='float',发现默认就是float64,长度也变回最初的4

>>> a.dtype = 'float'>>> aarray([ 0.0945377 ,  0.52199916,  0.62490646,  0.21260126])>>> a.shape(4,)>>> a.dtypedtype('float64')

把a变为整数,观察其信息

>>> a.dtype = 'int64'>>> aarray([4591476579734816328, 4602876970018897584, 4603803876586077261,       4596827787908854048], dtype=int64)>>> a.shape(4,)

改变dtype,发现数组长度翻倍!

>>> a.dtype = 'int32'>>> aarray([ 1637779016,  1069036447, -1764917584,  1071690807,  -679822259,        1071906619, -1611419360,  1070282372])>>> a.shape(8,)

改变dtype,发现数组长度再次翻倍!

>>> a.dtype = 'int16'>>> aarray([-31160,  24990,  13215,  16312,  32432, -26931, -19401,  16352,       -17331, -10374,   -197,  16355, -20192, -24589,  13956,  16331], dtype=int16)>>> a.shape(16,)

改变dtype,发现数组长度再次翻倍!

>>> a.dtype = 'int8'>>> aarray([  72, -122,  -98,   97,  -97,   51,  -72,   63,  -80,  126,  -51,       -106,   55,  -76,  -32,   63,   77,  -68,  122,  -41,   59,   -1,        -29,   63,   32,  -79,  -13,  -97, -124,   54,  -53,   63], dtype=int8)>>> a.shape(32,)

改变dtype,发现整数默认int32!

>>> a.dtype = 'int'>>> a.dtypedtype('int32')>>> aarray([ 1637779016,  1069036447, -1764917584,  1071690807,  -679822259,        1071906619, -1611419360,  1070282372])>>> a.shape(8,)

二、换一种玩法

很多时候我们用numpy从文本文件读取数据作为numpy的数组,默认的dtype是float64。
但是有些场合我们希望有些数据列作为整数。如果直接改dtype='int'的话,就会出错!原因如上,数组长度翻倍了!!!

下面的场景假设我们得到了导入的数据。我们的本意是希望它们是整数,但实际上是却是浮点数(float64)

>>> b = np.array([1., 2., 3., 4.])>>> b.dtypedtype('float64')

用 astype(int) 得到整数,并且不改变数组长度

>>> c = b.astype(int)>>> carray([1, 2, 3, 4])>>> c.shape(8,)>>> c.dtypedtype('int32')

如果直接改变b的dtype的话,b的长度翻倍了,这不是我们想要的(当然如果你想的话)

>>> barray([ 1.,  2.,  3.,  4.])>>> b.dtype = 'int'>>> b.dtypedtype('int32')>>> barray([         0, 1072693248,          0, 1073741824,          0,       1074266112,          0, 1074790400])>>> b.shape(8,)

numpy中的数据类型转换,不能直接改原数据的dtype!  只能用函数astype()。

以上是“numpy数据类型dtype转换实现的示例”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网行业资讯频道!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     801人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     348人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     311人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     432人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     220人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯