目录html
苦numpy久矣!python
Numpy 教程数组
import numpy as np
属性 | 解释 |
---|---|
ndarray.ndim | 返回ndarray的轴数,向量轴为1,矩阵是2,以此类推 |
ndarray.shape | 返回ndarray的形状(n,m) |
ndarray.size | 返回ndarray的大小,即元素的个数 |
ndarray.dtype | 返回ndarray的数据类型 |
ndarray.itemsize | 返回数据类型所占位数? |
ndarray.data |
a = np.arange(15).reshape(3, 5) a a.shape a.ndim a.dtype.name a.itemsize a.size type(a) b = np.array([6, 7, 8]) b type(b)
a = np.array(1,2,3,4) # WRONG a = np.array([1,2,3,4]) # RIGHT
c = np.array([[1, 2], [3, 4]], dtype = complex)
默认dtype=float.64app
np.zeros((3,4)) np.ones((2,3,4), dtype = np.int16) np.empty((2,3)) #这玩意儿输出的状况视内存而定,我输出的和上面的同样了。
np.zeros_like() np.ones_like() np.empty_like()
注意:连数据类型一并复制的
dom
np.arange(10, 30, 5) #array([10, 15, 20, 25]) 没有30, 跟range同样
np.arange() 的步长还能够为浮点数,这是range()所不具有的,不过教程并不推荐这种作法(彷佛是由于不稳定)。函数
np.arange(0, 2, 0.3)
np.linspace(0, 2, 9) #array([0. , 0.25, 0.5 , 0.75, 1. , 1.25, 1.5 , 1.75, 2. ])
*.rand() [0,1]的均匀分布ui
np.random.rand(3, 2, 2)
.randn() 标准正态分布
.randn() * \(\sigma\) + \(\mu\) 服从 \(\mathcal{N}(\mu,\sigma^2)\)spa
ndarray里面的 + - * / **都是元素对元素的。
code
a1 = np.arange(8) b1 = np.arange(8) a2 = a1.reshape(2, 4) b2 = b1.reshape(4, 2) c1 = np.arange(2) a1 @ b1 #140 a1.dot(b1) # 140 #a2 @ a2 | a2.dot(a2) Error a2 @ b2 #array([[28, 34], [76, 98]]) a2.dot(b2) #array([[28, 34], [76, 98]]) #a2 @ c1 | a2.dot(c1) Error b2 @ c1 #array([1, 3, 5, 7]) b2.dot(c1) #array([1, 3, 5, 7])
1.出现最后3个的缘由:c1.shape: (2, )htm
注意:俩个ndarray 作运算,“粗糙”的服从更加精准的。
都有个共同的关键字: axis
axis = 0 做用于列
axis = 1 做用于行
ndarray.cumsum() 累加和
a = np.arange(10) ** 3 #array([ 0, 1, 8, 27, 64, 125, 216, 343, 512, 729], dtype=int32) a[2] a[2:5] a[:6:2] a[: :-1] for i in a: print(i)
与list同样(没看出啥差异)
注意:多维的时候,c[1],就当成list来理解。
多维状况下的迭代,也能够用list来理解,就是一层层(一个轴一个轴)地往下走。
注意:上面的方法不改变数组自己 也能够np.*()
.ravel() #按行排列,返回一维数组 (C-style 啥意思不明白)
.T 转置
和reshape()不一样,用来改变对象自己
和列表和字典同样。
因为上面出现的状况,有些时候须要非对象绑定的复制(本身取的名字),就是a,b指向的内存并不是同一个。
比view()更极端 这点和list就不同了(list环境下是浅拷贝)
不懂
out 关键字按照教程打出错了,不知为什么。
关于out部分仍是出错
注意:diag()的时候有毛病啊,有毛病的啊,不晓得为何了,你妹!
只能用于一维的数组,且元素是非负整数