Python|numpy与pandas按列求均值忽略空值的一点点总结

import pandas as pd
import numpy as np

qq=np.array([[1,2,3,np.nan],[3,4,np.nan,5],[6,np.nan,5,7],[6,7,8,0]])

结果:

array([[ 1.,  2.,  3., nan],
       [ 3.,  4., nan,  5.],
       [ 6., nan,  5.,  7.],
       [ 6.,  7.,  8.,  0.]])
np.mean(qq,axis=0)

这样输出的是:array([ 4., nan, nan, nan]),即每列的均值,出现空值的列均值也为Nan

np.nanmean(qq,axis=0)

这样输出的是:array([4. , 4.33333333, 5.33333333, 4. ]),即忽略了空值进行均值

qq=pd.DataFrame(qq)
qq.mean(axis=0)

如果转为dataframe,再求均值,则可以直接得到忽略空值的均值:

0123
01.02.03.0NaN
13.04.0NaN5.0
26.0NaN5.07.0
36.07.08.00.0
结果为:
0    4.000000
1    4.333333
2    5.333333
3    4.000000
dtype: float64

ps:最大最小中值等均适用

  • 6
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值