标题中的英文首字母大写比较规范,但在python实际使用中均为小写。
2018年7月26日笔记
0.学习内容
前面6个学习内容要点链接:https://www.jianshu.com/p/75d275b58d52
Python科学计算库:Numpy需要掌握的知识:
7.Numpy中的对象;8.什么是ndarray;9.获取对象的维度和类型;10.创建ndarray对象;
11.Numpy数据类型;12.自定义数据类;13.ndarray索引访问;14.ndarray切片访问;
15.改变ndarray的维度;16.展平ndarray;17.ndarray的组合;
18.ndarray的切割;19.ndarray对象的属性。
7.Numpy中的对象
Numpy中提供了以下对象,用来解决标准Python的不足:
1.ndarray(N-dimensional array object)N维数组对象,存储单一数据类型的N维数组。
2.ufunc(universal function object)通用函数对象,对数组进行处理的函数。
8.什么是ndarray
Numpy中的ndarray是一个多维数组而且灵活的大数据容器,它由两部分组成:
1.实际的数据
2.描述这些数据的元数据
大部分的数组操作仅仅修改元数据部分,而不改变低层的实际数据。
另外,ndarray中所有元素的数据类型必须是一致的。
9.获取对象的维度和类型
import numpy as np
def info(matrix):
print("维度:",matrix.shape,"类型",matrix.dtype)
matrix1 = np.array([1,2,3,4,5])
info(matrix1)
matrix2 = np.arange(10).reshape(2,5)
info(matrix2)
10.创建ndarray对象
np.zeros方法,需要1个参数,参数数据类型为元祖,返回值数据类型为ndarray,其中元素数据类型默认为float64;
np.ones方法,需要1个参数,参数数据类型为元祖,返回值数据类型为ndarray,其中元素数据类型默认为float64;
np.full方法,需要2个参数,第1个参数数据类型为元祖,第2个参数数据类型为数字类型,可以为int或者float,
np.full方法返回值数据类型为ndarray,其中元素数据类型等同于np.full方法的第2个参数的数据类型;
np.eye方法,需要1个参数,参数数据类型为int型,返回值数据类型为ndarray,其中元素数据类型默认为float64。
import numpy as np
a = np.zeros((2, 2))
b = np.ones((2,2))
c = np.full((2,2),6)
d = np.eye(2)
print(a,a.dtype)
print(b,b.dtype)
print(c,c.dtype)
print(d,d.dtype)
11.Numpy数据类型
常用:
bool,布尔类型,值为True或者False
int32,整数,范围为-231--231 - 1,即-2147483648--2147483647
int64,整数,范围为-263--263 - 1
uint32,无符号整数,范围为0--2^32-1,即0--4294967295
uint64,无符号整数,范围为0--2^64-1
float32,单精度浮点型,其中1位表示正负号,8位表示指数,23位表示尾数
float64,双精度浮点型,其中1位表示正负号,11位表示指数,52位表示尾数
Numpy可以用字符编码来表示数据类型,这是为了兼容Numpy的前身Numeric
整数:i
无符号整数:u
单精度浮点型:f
双精度浮点型:d
布尔型:b
字符串:s
void:v
import numpy as np
matrix1 = np.arange(10,dtype='f')
matrix2 = np.arange(10,dtype='d')
print(matrix1.dtype)
print(matrix2.dtype)
12.自定义数据类
利用dtype创建一个存储商店库存信息的数据类
用一个长度为40的字符串来记录商品名称,用一个32位的整数来记录商品的库存数量,最后用一个32位的单精度浮点型来记录商品价格。
import numpy as np
commodity_field_list = [('name',np.str,40),('numitems',np.int32),('price',np.float32)]
commodity = np.dtype(commodity_field_list)
item_list = [('DVD',42,3.14),('Butter',13,2.72)]
item_ndarray = np.array(item_list,dtype=commodity)
print(item_ndarray)
for row in item_ndarray:
for value in row:
print(value,end='\t')
print()
13.ndarray索引访问
下面代码的最后一行matrix[2,2]和matrix2效果相同
import numpy as np
matrix = np.arange(25).reshape(5,5)
print(matrix.shape)
print(matrix[0])
print(matrix[1])
print(matrix[2,2],matrix[2][6])
14.ndarray切片访问
注意print(matrix[...,::-1])中的...写法。
import numpy as np
matrix = np.arange(24).reshape(2,3,4)
print("打印第1层的结果:")
print(matrix[1,...])
print("打印列翻转后的结果:")
print(matrix[...,::-1])
print("打印所有层第2行的结果:")
print(matrix[:,2])
15.改变ndarray的维度
改变ndarray维度有3种方法:1.调用ndarray对象的reshape方法;
2.改变ndarray对象的shape属性的值;3.调用ndarray对象的resize方法。
第2、3种方法会直接修改操作的数组,如下面代码所示:
matrix.resize(4,6)和matrix = matrix.reshape(4,6)效果相同
import numpy as np
print("reshape后没有进行赋值:")
matrix = np.arange(24).reshape(2,3,4)
matrix.reshape(4,6)
print(matrix)
print("reshape后进行赋值:")
matrix = np.arange(24).reshape(2,3,4)
matrix = matrix.reshape(4,6)
print(matrix)
print("改变matrix对象的shape属性")
matrix = np.arange(24).reshape(2,3,4)
matrix.shape = (4,6)
print(matrix)
print("resize后没有进行赋值")
matrix = np.arange(24).reshape(2,3,4)
matrix.resize(4,6)
print(matrix)
16.展平ndarray
使用ndarray对象的ravel方法
使用ndarray对象的flatten方法,效果与ravel功能相同。不过,flatten函数会请求分配内存来保存结果。
修改ndarray对象的ravel方法得到的对象,会同时导致原对象修改,即他们其实指向相同的内存地址。
17.ndarray的组合
英语单词学习:水平的,horizontal;垂直的,vertical;
行,row;列,column;堆,堆积,stack。
水平组合的3种方式:
垂直组合的3种方式:
np.concatenate方法axis参数默认为0
18.ndarray的切割
np.split(m,3,axis=1)和np.hsplit(m,3)作用相同
import numpy as np
m = np.arange(9).reshape(3,3)
print(np.split(m,3))
m_split = np.split(m,3,axis=1)
for i in m_split:
print(i)
19.ndarray对象的属性
1.ndim:数组的维数,
2.size:数组元素的总个数
3.itemsize:数组中元素在内存中占的字节数
4.nbytes:整个数组所占的内存空间
5.T:返回转置后的矩阵
6.flat:返回一个numpy.flatier对象,成为“扁平迭代器”,可以像遍历一维数组一样遍历任意的多维数组。
练习
1.创建一个一维数组,将其倒置,输出结果。
import numpy as np
m = np.arange(8)
print(m)
print(m[::-1])
2.创建一个行值是0到4的5*5矩阵
import numpy as np
m = np.arange(25).reshape(5,5)
m[1:] = m[0]
print(m)
3.创建一个10*10的矩阵,要求边框是1,里面是0。
下面代码利用了numpy的广播broadcast特性,这两种写法效果相同:
m[1:-1,1:-1] = np.zeros((8,8))
m[1:-1,1:-1] = 0
import numpy as np
m = np.ones((10,10))
m[1:-1,1:-1] = 0
print(m)