1 | import numpy as np |
创建数组
使用numpy生成list
1 | 1,3,5,7,9]) a = np.array([ |
array([1, 3, 5, 7, 9])
传入的参数不是同一结构将发生转换。
1 | 1,2.5,'3']) b = np.array([ |
array(['1', '2.5', '3'], dtype='<U32')
NumPy还提供了便捷地创建特定数组的方式。
1 | 3,4)) c = np.zeros(( |
array([[0., 0., 0., 0.],
[0., 0., 0., 0.],
[0., 0., 0., 0.]])
1 | 3,3)) d = np.ones(( |
array([[1., 1., 1.],
[1., 1., 1.],
[1., 1., 1.]])
1 | 15).reshape(3,5) e = np.arange( |
array([[ 0, 1, 2, 3, 4],
[ 5, 6, 7, 8, 9],
[10, 11, 12, 13, 14]])
1 | 0,15,3) f = np.arange( |
array([ 0, 3, 6, 9, 12])
基本操作
对数组中的算术操作是元素对应的。
1 | 2 a** |
array([ 1, 9, 25, 49, 81], dtype=int32)
1 | g = f-a |
array([-1, 0, 1, 2, 3])
1 | 5 a< |
array([ True, True, False, False, False])
在NumPy中,*
用于数组间元素对应的乘法,而不是矩阵乘法,矩阵乘法可以用dot()
方法来实现。
其结果是对两个数组对一个位置上的数进行加减乘除,数组算术操作的结果会存放在一个新建的数组中。
1 | 1,2], A = np.array([[ |
1 | A*B |
array([[0, 2],
[0, 4]])
1 | A.dot(B) |
array([[0, 3],
[0, 7]])
有些操作,如*=
,+=
,-=
,/=
等操作,会直接改变需要操作的数组,而不是创建一个新的数组。
1 | 2 A *= |
array([[2, 4],
[6, 8]])
当操作不同类型的数组时,最终的结果数组的类型取决于精度最宽的数组的类型。(即所谓的向上造型)
1 | 3, dtype=np.int32) a = np.ones( |
'float64'
1 | c = a+b |
'float64'
ndarray类实现了许多操作数组的一元方法,如求和、求最大值、求最小值等。
1 | A |
array([[2, 4],
[6, 8]])
1 | A.sum() |
20
1 | A.min() |
2
1 | A.max() |
8
NumPy还提供了操作数组中特定行和列的一元方法,通过制定不同的axis来实现。
1 | 0) # 计算行和 A.sum(axis= |
array([ 8, 12])
1 | 1) # 计算列和 A.sum(axis= |
array([ 6, 14])
shape操作
改变数组的shape
Numpy中数组shape由每个轴上元素的个数决定的。
1 | 3,4)) a = np.ones(( |
array([[1., 1., 1., 1.],
[1., 1., 1., 1.],
[1., 1., 1., 1.]])
1 | a.shape |
(3, 4)
NumPy中数组的shape是可以通过多种方式进行改变的,下面展示三种改变数组shape而不改变当前数组的方法。
1 | a.ravel() |
array([1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1.])
1 | 2,-1) a.reshape( |
array([[1., 1., 1., 1., 1., 1.],
[1., 1., 1., 1., 1., 1.]])
1 | a.T |
array([[1., 1., 1.],
[1., 1., 1.],
[1., 1., 1.],
[1., 1., 1.]])
NumPy还提供了可以直接修改原始数组shape的方法——resize()。
resize()方法和reshape()方法的最主要区别在于,resize() 方法会直接更改原数组。
1 | 2,6) a.resize( |
array([[1., 1., 1., 1., 1., 1.],
[1., 1., 1., 1., 1., 1.]])
数组堆叠和切片
NumPy支持将多个数据按照不同的轴进行堆叠。
hstack()
实现数组横向堆叠,vstack()
实现数组纵向堆叠。
1 | 10*np.random.random((2,2))) a = np.floor( |
1 | a |
array([[7., 7.],
[7., 4.]])
1 | b |
array([[2., 9.],
[2., 5.]])
1 | np.hstack((a,b)) |
array([[7., 7., 2., 9.],
[7., 4., 2., 5.]])
1 | np.vstack((a,b)) |
array([[7., 7.],
[7., 4.],
[2., 9.],
[2., 5.]])
除了支持数组的横向和纵向堆叠之外,NumPy还支持数组的横向和纵向分割。split()
方法默认为横线分割。
1 | 2) np.split(a, |
[array([[7., 7.]]), array([[7., 4.]])]
1 | 2) np.hsplit(a, |
[array([[7.],
[7.]]), array([[7.],
[4.]])]
1 | 2) np.vsplit(a, |
[array([[7., 7.]]), array([[7., 4.]])]
复制和视图
NumPy中,数组的复制有三种方式:
- Python通用的地址复制:通过 b = a 复制 a 的值,b 与 a 指向同一地址,改变 b 同时也改变 a。
- 通过视图ndarray.view() 复制值,当对 c 值进行改变会改变 a 的对应的值,而改变 c 的 shape 不改变 a 的 shape。
- ndarray.copy() 进行的完整的拷贝,产生一份完全相同的独立的复制。
地址复制
1 | 12) a = np.arange( |
array([ 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11])
1 | b = a |
array([ 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11])
1 | is a) print(b |
True
ndarray.view()
1 | c = a.view() |
array([ 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11])
1 | is a) print(c |
False
1 | 3,4) c.shape = ( |
array([[520, 1, 2, 3],
[ 4, 5, 6, 7],
[ 8, 9, 10, 11]])
1 | a |
array([520, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11])
ndarray.copy()
1 | d = a.copy() |
array([520, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11])
1 | is a) print(d |
False
1 | 4,3) d.shape=( |
array([[ 520, 1314, 2],
[ 3, 4, 5],
[ 6, 7, 8],
[ 9, 10, 11]])
1 | a |
array([520, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11])
NumPy功能和方法汇总
数组创建汇总
arange, array, copy, empty, empty_like, eye, fromfile, fromfunction, identity, linspace, logspace, mgrid, ogrid, ones, ones_like, r, zeros, zeros_like
数组转换
ndarray.astype, atleast_1d, atleast_2d, atleast_3d, mat
操作
array_split, column_stack, concatenate, diagonal, dsplit, dstack, hsplit, hstack, ndarray.item, newaxis, ravel, repeat, reshape, resize, squeeze, swapaxes, take, transpose, vsplit, vstack
问题
all, any, nonzero, where
排列
argmax, argmin, argsort, max, min, ptp, searchsorted, sort
运算
choose, compress, cumprod, cumsum, inner, ndarray.fill, imag, prod, put, putmask, real, sum
基础统计
cov, mean, std, var
基本线性代数
cross, dot, outer, linalg.svd, vdot