在Numpy中常用到的操做由扁平化操做,Numpy提供了两个函数进行此操做,他们的功能相同,但在内存上有很大的不一样.数组
先来看这两个函数的使用:函数
1 from numpy import * 2 3 a = arange(12).reshape(3,4) 4 print(a) 5 # [[ 0 1 2 3] 6 # [ 4 5 6 7] 7 # [ 8 9 10 11]] 8 print(a.ravel()) 9 # [ 0 1 2 3 4 5 6 7 8 9 10 11] 10 print(a.flatten()) 11 # [ 0 1 2 3 4 5 6 7 8 9 10 11]
能够看到这两个函数实现的功能同样,但咱们在平时使用的时候flatten()更为合适.在使用过程当中flatten()分配了新的内存,但ravel()返回的是一个数组的视图.视图是数组的引用(说引用不太恰当,由于原数组和ravel()返回后的数组的地址并不同),在使用过程当中应该注意避免在修改视图时影响本来的数组.这是什么意思咧,咱们经过代码来具体解释:spa
1 from numpy import * 2 3 a = arange(12).reshape(3,4) 4 print(a) 5 # [[ 0 1 2 3] 6 # [ 4 5 6 7] 7 # [ 8 9 10 11]] 8 9 # 建立一个和a相同内容的数组b 10 b = a.copy() 11 c = a.ravel() 12 d = b.flatten() 13 # 输出c和d数组 14 print(c) 15 # [ 0 1 2 3 4 5 6 7 8 9 10 11] 16 print(d) 17 # [ 0 1 2 3 4 5 6 7 8 9 10 11] 18 # 能够看到c和d数组都是扁平化后的数组,具备相同的内容 19 20 print(a is c) 21 # False 22 print(b is d) 23 # False 24 # 能够看到以上a,b,c,d是四个不一样的对象 25 26 # 但由于c是a的一种展现方式,虽然他们是不一样的对象,但在修改c的时候,a中相应的数也改变了 27 c[1] = 99 28 d[1] = 99 29 print(a) 30 # [[ 0 99 2 3] 31 # [ 4 5 6 7] 32 # [ 8 9 10 11]] 33 print(b) 34 # [[ 0 1 2 3] 35 # [ 4 5 6 7] 36 # [ 8 9 10 11]] 37 print(c) 38 # [ 0 99 2 3 4 5 6 7 8 9 10 11] 39 print(d) 40 # [ 0 99 2 3 4 5 6 7 8 9 10 11]
经过以上的分析,在实际应用中应尽可能使用flatten()函数,这样避免意外的错误.code