百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分类 > 正文

python数据分析numpy基础之mean用法和示例

ztj100 2024-10-28 21:15 31 浏览 0 评论

1 python数据分析numpy基础之mean用法和示例

python的numpy库的mean()函数,用于计算沿指定轴(一个轴或多个轴)的算术平均值。

用法

 numpy.mean(a, axis=None, dtype=None, out=None, keepdims=<no value>, *, where=<no value>)

描述

返回数组元素的平均值。长度为0的数组的mean为nan。

等效于对指定轴求后,然后除以轴大小,即为其平均值。

入参

a:必选,array_like,数组或列表或元组,表示需要计算平均数的元素的数组。

axis:可选,默认为None,整数或整数元组,表示需要计算平均值的一个或多个轴。

1.1 入参a

numpy.mean()的入参a,为必选入参,可以为数组、列表、元组。如果a长度为0,则返回NaN。表示需要求平均值的数组。

 >>> import numpy as np
 # 入参a为列表
 >>> np.mean([1,2,3,4,5])
 3.0
 # 入参a为元组
 >>> np.mean((1,2,3,4,5))
 3.0
 # 入参a为数组
 >>> np.mean(np.array([1,2,3,4,5]))
 3.0
 # 入参a的长度为0,返回NaN,并且第1次报错,后面不再报错
 >>> np.mean(np.array([]))
 Warning (from warnings module):
   File "D:\python3\lib\site-packages\numpy\core\fromnumeric.py", line 3441
     out=out, **kwargs)
 RuntimeWarning: Mean of empty slice.
 
 Warning (from warnings module):
   File "D:\python3\lib\site-packages\numpy\core\_methods.py", line 189
     ret = ret.dtype.type(ret / rcount)
 RuntimeWarning: invalid value encountered in double_scalars
 nan
 >>> np.mean(np.array([]))
 nan

1.2 入参axis为整数

numpy.mean()的入参axis为可选入参,默认为None,表示求全部元素的平均值。

若axis=n为整数,则对指定轴n的元素求平均值,即,先对同轴同方向的元素求和,再除以同轴同方向的元素个数(轴大小),即为其平均值。

若axis=负数,则-1对应最后一个轴,-2倒数第2个轴,依此类推。

 >>> import numpy as np
 # 创建一个三维数组,大小为(2,3,4)
 >>> ar3=np.arange(24).reshape(2,3,4)
 >>> ar3
 array([[[ 0,  1,  2,  3],
         [ 4,  5,  6,  7],
         [ 8,  9, 10, 11]],
 
        [[12, 13, 14, 15],
         [16, 17, 18, 19],
         [20, 21, 22, 23]]])
 # 入参 axis默认为None,求全部元素的平均值
 >>> np.mean(ar3)
 11.5
 # axis=整数,同轴同方向求和,再除以轴大小
 # axis=0,先对0轴求和,再除以2
 >>> np.mean(ar3,axis=0)
 array([[ 6.,  7.,  8.,  9.],
        [10., 11., 12., 13.],
        [14., 15., 16., 17.]])
 # np.mean(ar3,axis=0)=np.sum(ar3,axis=0)/2
 >>> np.sum(ar3,axis=0)/2
 array([[ 6.,  7.,  8.,  9.],
        [10., 11., 12., 13.],
        [14., 15., 16., 17.]])
 # axis=1,先对1轴求和,再除以3
 >>> np.mean(ar3,axis=1)
 array([[ 4.,  5.,  6.,  7.],
        [16., 17., 18., 19.]])
 # np.mean(ar3,axis=1)=np.sum(ar3,axis=1)/3
 >>> np.sum(ar3,axis=1)/3
 array([[ 4.,  5.,  6.,  7.],
        [16., 17., 18., 19.]])
 # axis=2,先对2轴求和,再除以4
 >>> np.mean(ar3,axis=2)
 array([[ 1.5,  5.5,  9.5],
        [13.5, 17.5, 21.5]])
 # np.mean(ar3,axis=2)=np.sum(ar3,axis=2)/4
 >>> np.sum(ar3,axis=2)/4
 array([[ 1.5,  5.5,  9.5],
        [13.5, 17.5, 21.5]])
 # axis=负数,则-1对应最后一个轴,-2倒数第2个轴,依此类推 
 >>> np.mean(ar3,axis=-1)
 array([[ 1.5,  5.5,  9.5],
        [13.5, 17.5, 21.5]])

1.3 入参axis为元组

numpy.mean()的入参axis若为轴的元组,则对多个轴求平均值。

先对多个轴的元素求和,再除以多个轴的大小的乘积,即为其平均值。

axis=(m,n)等效于axis=(n,m)。

 >>> import numpy as np
 # 创建一个三维数组,大小为(2,3,4)
 >>> ar3=np.arange(24).reshape(2,3,4)
 >>> ar3
 array([[[ 0,  1,  2,  3],
         [ 4,  5,  6,  7],
         [ 8,  9, 10, 11]],
 
        [[12, 13, 14, 15],
         [16, 17, 18, 19],
         [20, 21, 22, 23]]])
 # axis=元组,对多个轴求和,再除以多个轴大小的乘积
 # axis=(0,1),先对0和1轴求和,再除以6,6=2*3
 >>> np.mean(ar3,axis=(0,1))
 array([10., 11., 12., 13.])
 >>> np.sum(ar3,axis=(0,1))/6
 array([10., 11., 12., 13.])
 # axis=(1,0)等效于axis=(0,1)
 >>> np.mean(ar3,axis=(1,0))
 array([10., 11., 12., 13.])
 # axis=(0,1),先对0和2轴求和,再除以8,8=2*4
 >>> np.mean(ar3,axis=(0,2))
 array([ 7.5, 11.5, 15.5])
 >>> np.sum(ar3,axis=(0,2))/8
 array([ 7.5, 11.5, 15.5
 # axis=(1,2),先对1和2轴求和,再除以12,12=3*4
 >>> np.mean(ar3,axis=(1,2))
 array([ 5.5, 17.5])
 >>> np.sum(ar3,axis=(1,2))/12
 array([ 5.5, 17.5])

2 END

本文首发微信公众号:梯阅线条

更多内容参考python知识分享或软件测试开发目录。

相关推荐

再说圆的面积-蒙特卡洛(蒙特卡洛方法求圆周率的matlab程序)

在微积分-圆的面积和周长(1)介绍微积分方法求解圆的面积,本文使用蒙特卡洛方法求解圆面积。...

python编程:如何使用python代码绘制出哪些常见的机器学习图像?

专栏推荐...

python创建分类器小结(pytorch分类数据集创建)

简介:分类是指利用数据的特性将其分成若干类型的过程。监督学习分类器就是用带标记的训练数据建立一个模型,然后对未知数据进行分类。...

matplotlib——绘制散点图(matplotlib散点图颜色和图例)

绘制散点图不同条件(维度)之间的内在关联关系观察数据的离散聚合程度...

python实现实时绘制数据(python如何绘制)

方法一importmatplotlib.pyplotaspltimportnumpyasnpimporttimefrommathimport*plt.ion()#...

简单学Python——matplotlib库3——绘制散点图

前面我们学习了用matplotlib绘制折线图,今天我们学习绘制散点图。其实简单的散点图与折线图的语法基本相同,只是作图函数由plot()变成了scatter()。下面就绘制一个散点图:import...

数据分析-相关性分析可视化(相关性分析数据处理)

前面介绍了相关性分析的原理、流程和常用的皮尔逊相关系数和斯皮尔曼相关系数,具体可以参考...

免费Python机器学习课程一:线性回归算法

学习线性回归的概念并从头开始在python中开发完整的线性回归算法最基本的机器学习算法必须是具有单个变量的线性回归算法。如今,可用的高级机器学习算法,库和技术如此之多,以至于线性回归似乎并不重要。但是...

用Python进行机器学习(2)之逻辑回归

前面介绍了线性回归,本次介绍的是逻辑回归。逻辑回归虽然名字里面带有“回归”两个字,但是它是一种分类算法,通常用于解决二分类问题,比如某个邮件是否是广告邮件,比如某个评价是否为正向的评价。逻辑回归也可以...

【Python机器学习系列】拟合和回归傻傻分不清?一文带你彻底搞懂

一、拟合和回归的区别拟合...

推荐2个十分好用的pandas数据探索分析神器

作者:俊欣来源:关于数据分析与可视化...

向量数据库:解锁大模型记忆的关键!选型指南+实战案例全解析

本文较长,建议点赞收藏,以免遗失。更多AI大模型应用开发学习视频及资料,尽在...

用Python进行机器学习(11)-主成分分析PCA

我们在机器学习中有时候需要处理很多个参数,但是这些参数有时候彼此之间是有着各种关系的,这个时候我们就会想:是否可以找到一种方式来降低参数的个数呢?这就是今天我们要介绍的主成分分析,英文是Princip...

神经网络基础深度解析:从感知机到反向传播

本文较长,建议点赞收藏,以免遗失。更多AI大模型应用开发学习视频及资料,尽在...

Python实现基于机器学习的RFM模型

CDA数据分析师出品作者:CDALevelⅠ持证人岗位:数据分析师行业:大数据...

取消回复欢迎 发表评论: