np.array(100)
和np.array([100])
之间有什么区别?我知道后者是一个包含单个值(100
(的1D数组,但前者叫什么?
这是一个0d数组。它可以以许多与其他阵列相同的方式使用,当然还需要形状和数据型相容剂。
In [545]: x=np.array(3)
In [546]: x.shape
Out[546]: () # empty tuple
In [547]: x.ndim
Out[547]: 0
In [548]: x.ravel()
Out[548]: array([3]) # as with other arrays, ravel makes a 1d array
In [549]: x.reshape(1,1,1) # reshape to 3d
Out[549]: array([[[3]]])
In [550]: x.item() # extracting that element
Out[550]: 3
In [551]: x[()] # another extracting
Out[551]: 3
In [552]: type(_)
Out[552]: numpy.int64
In [553]: type(x.item())
Out[553]: int
CCD_ 4和CCD_。一个返回python对象,另一个返回";numpy标量";。
更多关于numpy标量的信息:
https://numpy.org/doc/stable/reference/arrays.scalars.html#methods
我们遇到0d数组的一个常见情况是,对象被包裹在数组中,例如通过np.save
。
In [556]: d = np.array({'foo':'bar'})
In [557]: d
Out[557]: array({'foo': 'bar'}, dtype=object)
In [558]: d.shape
Out[558]: ()
In [559]: d.item()['foo']
Out[559]: 'bar'
0d阵列的值可以更改
In [562]: x[...] = 4
In [563]: x
Out[563]: array(4)