Python中是否有内置或标准的库方法来计算一组数字的算术平均值(一种平均值)?
当前回答
如果你正在使用python >= 3.8,你可以使用统计模块中引入的fmean函数,它是标准库的一部分:
>>> from statistics import fmean
>>> fmean([0, 1, 2, 3])
1.5
它比统计数据还要快。均值函数,但它事先将其数据点转换为浮点数,因此在某些特定情况下可能不太准确。
你可以在这里看到它的实现
其他回答
你甚至不需要numpy或scipy…
>>> a = [1, 2, 3, 4, 5, 6]
>>> print(sum(a) / len(a))
3
我总是认为avg是省略从内置/stdlib,因为它是一样简单
sum(L)/len(L) # L is some list
任何警告都将在本地使用的调用者代码中解决。
值得注意的事项:
非浮点结果:在python2中,9/4为2。要解析,使用float(sum(L))/len(L)或从__future__导入除法 除以0:列表可能为空。解决: 如果不是L: 提高WhateverYouWantError (" foo ") avg = float(sum(L))/len(L)
使用scipy:
import scipy;
a=[1,2,4];
print(scipy.mean(a));
其他人已经发布了非常好的答案,但有些人可能仍然在寻找一个经典的方法来查找Mean(avg),所以我在这里发布这个(在Python 3.6中测试的代码):
def meanmanual(listt):
mean = 0
lsum = 0
lenoflist = len(listt)
for i in listt:
lsum += i
mean = lsum / lenoflist
return float(mean)
a = [1, 2, 3, 4, 5, 6]
meanmanual(a)
Answer: 3.5
使用statistics.mean:
import statistics
print(statistics.mean([1,2,4])) # 2.3333333333333335
它从Python 3.4开始可用。对于3.1-3.3用户,PyPI上的stats名称下提供了该模块的旧版本。只需将统计数据更改为统计数据。
推荐文章
- “克隆”行或列向量
- 在python shell中按方向键时看到转义字符
- 在pip install中方括号是什么意思?
- 使用Matplotlib以非阻塞的方式绘图
- 使用sklearn缩放Pandas数据框架列
- 如何创建关键或附加一个元素的关键?
- virtualenv的问题-无法激活
- 是否可以使用scikit-learn K-Means聚类来指定自己的距离函数?
- 如何在Python中删除文本文件的文件内容?
- 一个干净、轻量级的Python扭曲的替代品?
- 在Python中从字符串中移除所有非数字字符
- 在Python中,如何以排序的键顺序遍历字典?
- Python中的多行f-string
- 批量归一化和退出的排序?
- Python中的“@=”符号是什么意思?