1.创建数组 数组也是对象,与列表不同,数组的的元素的类型必须是相同的,且数组一旦确定,其轴的数量就不能再变化。创建数组大致有以下三种方法。

1.1 np.array()创建数组

1.1.1创建一维数组

Array1=np.array([1,2,3,4]);这条语句创建了一个有四个元素(整数)组成的一维数组。

Array=np.array(Array1,dtype=float) 这条语句创建了一个有四个元素(整数)组成的一 维数组,它的各个元素是为浮点数。

当定义数组时未显式指定dtype时,NumPy会自行推断元素类型。

1.1.2 创建二维数组

Array2=np.array([[1,2,3,4],[1,2,3,4]]); 此处创建了一个二维数组。

Array2=np.array([1,2,3,4],ndim=2);此处创建的也是一个二维数组

1.1.3 创建三维数组

Array3=np.array([[1,2,3,4],[1,2,3,4]]);

Array4=np.array([[4,5,16,7,3],[5,2,3,8]]);

MutiArray=np.array([Array3,Array4]),此处的MutiArray便是一个三维数组。

注意: 当向np.array()中传入列表的时候,列表中各个元素的长度应一致,否则系统可能不会报错,但是最终得到的数组对象可能并不是我们想要的。如定义时使用arrayTest=np.array([[1,2,3],[4,5,6,7],[11,12]]);输出arrayTest的时候,其结果如下:array([list([1,2,3]),list(4,5,6,7),list(11,12)]);

1.2 用函数创建数组

1.2.1 np.zeros((shape,dtype=arrayType,order=’C’)) 它创建一个完全由0组成的数组,shape是以元组形式声明此数组的形状,arrayType是元素的类型,order后的值是其在数据存储区的排列的格式,‘C’是按行排,‘F’是按列排,默认order=’C’.

ArrayTest=np.zeros((2,3),dtype=float,order=’C’);定义了一个输出如下所示的二维数组:

array([[0.,0.,0.],[0.,0.,0.]]);

1.2.2下表中列出的是NumPy中创建特殊数组的函数:

函数

说明

asarray

输入列表、元组或由它们组成的嵌套对象或数组,返回一个数组。如果输入参数是数组,则返回此数组本身

arange

根据开始值、结束值和步长创建一个数组

ones、ones_like

ones根据指定的形状(元组方式)和元素类型,创建元素值为1的数组,ones_like创建一个与指定数组完全一样但元素值都为1的数组

zeros、zeros_like

与上雷同,但元素值都是0

Empty、empty_like

同上,但没有填充任何元素数据,但分配了内存空间

Eye、identity

创建对角线元素是1其它元素是0的二维数组

diag

创建对角线元素是指定值其它元素是0的二维数组

linespace

根据开始值、结束值元素是等差数列的数组

logspage

根据开始值、结束值、元素数量和对数底创建元素是等比数列的数组

1.2.3除了上述的函数,还可以用

dir(

np)命令显示出的

from开头的方法创建数组,如

frombuffer、

fromfile、

fromfunction、

fromregex、

fromstring等。

1.3 使用np.dtype()创建自定义类型的数组

首先,我们创建自定义类my_type如下所示

my_type=np.dtype({“names”:[‘book’,’version’],”formats”:[‘S40’,np.int]});或者

my_type=np.dtype([(‘book’,’S40’),(‘version’,np.int)]);

然后,我们就可以定义元素为my_type类型的数组了:

my_books=np.array([“bookname1”,1],[“bookname2”,2],dtype=my_type)

2.查看数组属性

2.1查看当前对象属性和方法:dir(array)或array?

2.2数组元素的类型:array.dtype

2.3数组的形状array.shape

2.4数组的维度

array.ndim

3. 数组的轴

生活中,我们描述矩阵的形状用一维、二维和三维等等,对应的其大小会用n1 X n2 X n3……去描述,numpy中的数组就通过ndim和shape来为我们描述一个数组的维度和大小。

下图描述了了一个二维数组的维度和大小:


同样的道理,为了能唯一访问到高维数组中某个元素,必须指明每一个维度的值,我们可以试试对于上述

2

维数组用不同维度去访问,其中最后两种访问形式是等价的:


4. 快速生成数组

一般的做法是我们生成一维数组,然后通过reshape方法将其变成我们想要的形状的数组,而一维数组的生成可以用arange函数(生成指定范围内的整数数组)、linspace函数(在一定范围内生成指定个数的小数数组)。


5. 切片

Python中list对象一个很重要的特征就是切片,同样的,在numpy的数组也支持切片,但是list的切片生成的是原对象的一个copy,numpy数组生成的切片中的元素是共享内存的。


6. 数组的变形

之前我们已经用过了reshape方法去改变一个数组的形状,但我们也可以通过改变数组对象的shape属性来改变数组的形状。


反过来,如果我们要将高维数组变成一维数组可以通过flatten()和reval()函数,不过前者是返回原对象的一个copy,后者却是和父本的元素共享同一个内存空间。


7. 数组的组合和分割

在我们将来进行数组分析的时候,可能会将不同的数组进行组合和分割,所以,numpy也为我们准备了对应的函数。

hstack()函数内帮我们将多个数组沿1轴(水平方向)的方式连接起来,其作用类似于在concatenate函数中指明axis=1(在numpy中,很多操作都是和轴有关的,axis=0表示0轴,即按行的方式)。同样的道理,我们可以用vstack()函数将数组沿0轴(垂直方向)连接起来,下图只给出水平方向的实例,大家可以去试试垂直方式的用法。


会了组合,那么也就不应该忘了分割,即split()函数,同样的,必须要指明该函数的按什么轴去分割,即axis的值,当axis=0时,等价垂直分割函数vsplit();当axis=1时,等价水平分割函数hsplit()。


7. 数组的改编

作者把“改编”定义为包括添加、插入、删除这3个操作的统一说法,numpy中这3个操作分别对应于append()、insert()和delete()3个函数。使用这3个函数如果不声明轴axis的值,生成的将是改编后数组的一维数组形式,无论之前是多少维的,此时,就相当于改编后又调用了flatten()函数,具体用法可以参照下图:


8. 数组的运算

Numpy的诞生本就为了科学计算和数值处理,所以,我们想对整个数组进行加减乘除等运算时,直接把每个数组变量看成一个普通的数字就行了。

不仅是简单的加减乘除,他还支持指数运算、对数运算、三角函数等多种运算(下图最后一个事例因为计算了log10(0)发生了错误……)


限于篇幅,无法一一演示所有函数