Numpy中array数组对象的储存方式(n,1)和(n,)的区别

本文主要介绍了Numpy中array数组对象的储存方式(n,1)和(n,)的区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

之前一直傻傻分不清(n,1)和(n,)之间的区别,这里做一下总结,希望度过此文章的小伙伴都能明白。

例如如果我们创建一个包含10个整型数的数组 a :

import numpy as np a=np.arange(10) a

结果为:

array([0, 1, 2, 3, 4, 5, 6, 7, 8, 9])

则 a 包含了一个数据缓冲区,储存成如下的样子:

在这里插入图片描述

a.shape

数据的维度为:(10,)

在这里,shape=(10,)意味着这个数组仅仅被一个索引支配:从0到9。从概念上讲,假如我们使用这个单独的索引给 a 打上标签,那么 a 将看起来像这样:

在这里插入图片描述

reshape一个数组的操作不会改变数据缓冲区,而是创建一个新的解释数据的视窗。

b=a.reshape((2,5)) b

结果为:

array([[0, 1, 2, 3, 4],
       [5, 6, 7, 8, 9]])

这样我们的数据就会有两个维度来控制,其中一个的范围是从0到4,另一个的范围是从5到9。

我们举个例子,我们想要取出里面的1值,如何切片操作?

b[0,1]

总结:

第一个形状为(10,)的数组是一维数组。它的结构应该与此类似:a=[1,2,3,4,5]

第二个形状为(10,1)。 类似于b=[[1],[2],[3],[4],[5]]

到此这篇关于Numpy中array数组对象的储存方式(n,1)和(n,)的区别的文章就介绍到这了,更多相关Numpy array数组对象(n,1)和(n,)内容请搜索0133技术站以前的文章或继续浏览下面的相关文章希望大家以后多多支持0133技术站!

以上就是Numpy中array数组对象的储存方式(n,1)和(n,)的区别的详细内容,更多请关注0133技术站其它相关文章!

赞(0) 打赏
未经允许不得转载:0133技术站首页 » python