当前位置:   article > 正文

一文搞定numpy用法_numpy格式

numpy格式

一文搞定numpy用法

1 简介

本文总结了numpy 常见的用法 ,全文阅读大约需要 10 10 10分钟,可以按目录按需使用 。

1.1 numpy是什么?

NumPy是使用Python进行科学计算的基础包,主要用于对多维数组计算。numpy这个词来源于两个单词Numerical和Python。所以我之前读成“扭爬哎”是错的,应该是“难爬哎”。
在这里插入图片描述

1.2 numpy的优势

  • NumPy对于执行各种数学任务非常有用,如数值积分、微分、内插、外推等。可以看成python中的MATLAB。
  • 一个强大的N维数组对象,计算强大高效快速。
  • 可以定义任意数据类型,能够无缝快速地与各种数据库集成。

1.3 安装

配置好python之后,配置numpy的最快也是最简单的方法是在命令提示符中输入下命令:
pip install numpy

2 生成numpy数组

numpy提供的最重要的数据结构是一个称为NumPy数组的强大对象, numpy数组是通常的Python数组的扩展。NumPy数组配备了大量的函数和运算符,让我们看看如何快速定义一维NumPy数组。

2.1 生成方法汇总

命令数组
np.array([1,2,3,4])列表转为数组
np.arange(start, stop, step)整数序列数组
np.linspace(start, stop,num,endpoint=True)等差数列
np.logspace(start, stop,num,base)等比数列
np.zeros(shape, dtype=float, order=‘C’)全为 0 0 0的数组
np.ones(shape, dtype=float, order=‘C’)全为 1 1 1的数组
np.full((shape, fill_value)全为fill_value的数组
np.empty(shape,int)数组内容是随机的
np.zeros_like()生产一个和一样形状的数组
np.eye(N,M)生产N*M的单位矩阵
np.diag()对角向量和对角阵切换
np.fromstring(str,dtype=np.int8)字符串转为数组
np.fromfunction(function, shape)函数生成数组

2.2 代码示例

import numpy as np # 导入numpy模块
a=np.array([1,2,3,4],dtype='int') # 生成一维整形数组,dtype指定数组类型
# dtype参数泛类可选 int,float,complex,bool,string等
" array([1, 2, 3, 4]) "

a=np.arange(1,10,2) # 等差序列不包含结束值。
" array([1, 3, 5, 7, 9]) "

a=np.linspace(1,9,5,dtype="float",endpoint=True) 
# 等差数组,注意第三个参数是数组元素个数,endpoint=True指定数组包含结束值.
" array([1., 3., 5., 7., 9.]) "

a=np.logspace(1,3,3, base=10, endpoint=True) # 对数等比数列,生成的数列以base=10取对数就是np.linspace(1,3,3)
" array([  10.,  100., 1000.]) "

# 可以生成任意等比数列,例如:
a=np.logspace(1,5,5, base=2, endpoint=True)
" array([ 2.,  4.,  8., 16., 32.]) "

a=np.zeros(shape=4) # 生成全为0的数组
" array([0., 0., 0., 0.]) "

a=np.ones(shape=(2,2),order='C') #shape 指定数组形状,order指定排布方向,C为行,F为列。
""  array([[1., 1.],
           [1., 1.]])  ""
           
a=np.full((2,3),10) # shape指定形状,fill_value指定填充的值
""  array([[10, 10, 10],
           [10, 10, 10]])  ""
           
b=np.zeros_like(a) # 和a数组一样全为0的数组
"" array([[0, 0, 0],
          [0, 0, 0]])  ""  
          
a=np.eye(2,2,k=0) # 生成单位矩阵  # 参数k控制为1的对角线位置, k=0是主对角线, k=1为右上↗, k=-1为左下↙。
"" array([[1., 0.],
          [0., 1.]])  "" 
          
a = np.identify(2) # 即np.eye中N=M的情况
""array([[1., 0.],
         [0., 1.]])""
       
a = np.array([1,2]) 
a = np.diag(a) 
"" array([[1, 0],
          [0, 2]]) ""    #  np.diag() 生成对角线矩阵
       
a = np.diag(a)
""  array([1, 2])""   # np.diag() 提取对角线元素

a=np.empty((2,2),int)# 数组内容是随机的,不占用内存
""  array([[1506027568,  573],
           [         0,   0]])  ""
           
a=np.fromstring('1, 2', dtype=int, sep=',') # 字符串转换成数组
" array([1, 2]) "

def f1(x):
    return 2*x
a=np.fromfunction(f1,(4,)) # 索引值为自变量,函数值为数组值
" array([0., 2., 4., 6.]) "

def f2(x,y):
    return x+y
a=np.fromfunction(f2,(3,3)) # 二维数组则需要二元函数 , 变量分别为各个维度的索引, 更高维也是一样。
"""
array([[0., 1., 2.],
       [1., 2., 3.],
       [2., 3., 4.]])
"""
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70

3 数组属性

对数组操作之前,我们必须知道数组的底细,除了打印出来看之外,下面属性可以快速了解数组 。

a = np.array([[1,2,3],[4,5,6],[7,8,9]])
type(a) 
 ' <class 'numpy.ndarray'> '   # 谁能告诉我为什么叫 ndarray
 a.dtype # 数组数据类型
 '  dtype('int32') ' 
 a.size # 数组元素个数 
 " 9 "
 a.shape # 数组形状
 " (3, 3) "
 a.ndim # 数组的维数
 " 2 "
 a.itemsize # 每个项占用的字节数
 " 4 "
 a.nbytes # 数组中的所有数据消耗掉的字节数
 " 36 "
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15

4 数组操作

关于np数组的形状操作,这篇文章数组的变形解释的直观清楚,请参考这篇。

5 使用numpy运算

5.1 四则运算

使用numpy,可以轻松地在数组上执行数学运算, 加减乘除直接可以通过 + − ∗ / +-*/ +/计算。

a = np.array([[1.0, 2.0], [3.0, 4.0]]) 
b = np.array([[5.0, 6.0], [7.0, 8.0]]) 
Sum= a + b 
Difference = a - b 
Product = a * b 
Quotient = a / b 
"""
Sum = array([[ 6.,  8.],[10., 12.]])
Difference = array([[-4., -4.],[-4., -4.]])
Product =array([[ 5., 12.],[21., 32.]])
Quotient = array([[0.2 , 0.33333333], [0.42857143, 0.5 ]])
"""
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12

5.2 矩阵运算

注意乘法运算符( ∗ * )执行逐元素乘法而不是矩阵乘法。矩阵乘法是下面的方法

matrix_product = np.dot(a,b) 
"" matrix_product = array([[19., 22.],
                           [43., 50.]])  ""
a@b 
""array([[19., 22.],
         [43., 50.]])  ""                        
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

矩阵求逆

a = np.array([[1,0],[0,2]]) 
a_inv = np.linalg.inv(a) ;print(a_inv) 
""array([[1., 0.],
         [0., 0.5.]])"" 
# 或者转化matirx,使用a.I 
A = np.matrix(a)
print(A.I)
""[[1.  0. ]
   [0.  0.5]]""
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

矩阵转置

a = np.array([[1,2],[3,4]])
a.T 
""array([[1, 2],
         [3, 4]])""
  • 1
  • 2
  • 3
  • 4

5.3 基础统计计算

下面的操作都可以对数组 所有元素 或者某一轴 进行, 如果没有指定轴就是对所有元素计算 。

a = np.array([[1,2,3],[4,5,6],[7,8,9]])
a.sum() " 45 "  # 计算所有元素 # 下面都以定轴举例 
a.sum(axis=0) # 指定第0轴求和
 " array([12, 15, 18]) "
a.mean(axis=0) # 均值
" array([4., 5., 6.]) "
a.std(axis=0) # 标准差
" array([2.44948974, 2.44948974, 2.44948974]) "
a.var(axis=0) # 方差
" array([6., 6., 6.]) "
a.prod(axis=0) # 定轴乘积
" array([ 28,  80, 162]) "
a.ptp(axis=0) # 定轴极差
" rray([6, 6, 6]) "
a.min()# a.max # 数组中最小最大值
" 1 "
a.argmin(axis=0) # argmax # 数组中最小最大值的索引
" array([0, 0, 0]) "
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18

6 使用numpy读取与保存数据

6.1 npy格式

numpy数据的格式为.npy 。

a = np.array([[1,2,3],[4,5,6],[7,8,9]])
np.save("npy_data_a.npy",a)  # 参数分别为保存的文件路径# 需要保存的数组  
np.load("npy_data_a.npy") # 加载路径 
"""
array([[1, 2, 3],
       [4, 5, 6],
       [7, 8, 9]])
 """
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

6.2 txt格式

np.savetxt("tet_data_a.txt",a) # 保存为txt文件数据
np.loadtxt("tet_data_a.txt") # 加载txt数据
"""
array([[1, 2, 3],
       [4, 5, 6],
       [7, 8, 9]])
 """
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

6.3 csv格式

np.savetxt("csv_data_a.csv",a,delimiter=",")  # 保存为csv , delimiter为分隔符
b,c=np.loadtxt('csv_data_a.csv',delimiter=",",usecols=(1,2),max_rows=2,encoding='utf-8',unpack=True)
# 加载csv数据
# delimiter为分隔符 # usecols 为指定的列 # max_rows 加载最大行数 
# encoding 选择编码方式 ,编码方式不同会报错 # unpack 是否解包,这里两列分别解包给b,c
"" b=array([2., 5.]) 
   c=array([3., 6.]) ""
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

7 索引

7.1 切片

numpy切片和列表切片一样 ,方法是 np.array [起始 : 终点 : 步长] ,返回数组包含起始值不包含终点值, 起始和终点位置为负,则从后面数,倒数第一为 − 1 -1 1 。步长为负则从后面向前切片 。

a=np.arange(6) " array([0, 1, 2, 3, 4, 5]) "
a[0:5:2]  " array([0, 2, 4]) "
a[-1:2:-1] " array([5, 4, 3]) " 
  • 1
  • 2
  • 3

7.2 位置向量索引

location=[0,3]  #指定任意位置 
a[location]  " array([0, 3]) "
  • 1
  • 2

7.3 bool索引

a>3  "  array([False, False, False, False,  True,  True]) "
a[a>3] " array([4, 5]) "
a[(a>3)&(a<5)]  " array([4]) "
  • 1
  • 2
  • 3

7.4 多维索引

多维索引就是在每一维分别做一维索引 。

a = np.array([[1,2,3],[4,5,6],[7,8,9]])
a[1,2] " 6 "
a[::2 , np.array([False,True,True])]  # 第 0 维度切片,第 1 维度布尔值索引 ,可以看成在各轴独立的指定
"" array([[2, 3],
         [8, 9]]) ""
  • 1
  • 2
  • 3
  • 4
  • 5

感谢您在茫茫的网络世界中阅读了本文, 真心希望没有浪费您宝贵的时间,期待您指出文中的不足!

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/笔触狂放9/article/detail/620083
推荐阅读
相关标签
  

闽ICP备14008679号