gpt4 book ai didi

python - Pandas 中任意分布的频率均值计算

转载 作者:太空宇宙 更新时间:2023-11-04 02:31:09 28 4
gpt4 key购买 nike

我有一个大型数据集,其值范围为 1 到 25,分辨率为 o.1。分布本质上是任意的,模式值为 1。样本数据集可以是这样的:

1,
1,
23.05,
19.57,
1,
1.56,
1,
23.53,
19.74,
7.07,
1,
22.85,
1,
1,
7.78,
16.89,
12.75,
15.32,
7.7,
14.26,
15.41,
1,
16.34,
8.57,
15,
14.97,
1.18,
14.15,
1.94,
14.61,
1,
15.49,
1,
9.18,
1.71,
1,
10.4,

如何评估不同范围(0-0.5、0.5-1 等)的计数并找出它们在 pandas、Python 中的频率平均值。

预期的输出可以是

值范围(f)出现(n)f*n

 1  
2.2 1-2 2 3
2.8 2-3 3 7.5
3.7 3-4 2 7
5.5 4-5 1 4.5
5.8 5-6 3 16.5
4.3
2.7 sum- 11 38.5
3.5
1.8 frequency mean 3.5
5.9

最佳答案

你需要cut用于分箱,然后将 CategoricalIndex 转换为 IntervalIndex 以获得 mid 值,通过 mul 进行多列,求和和最后除法标量:

df = pd.DataFrame({'col':[1,2.2,2.8,3.7,5.5,5.8,4.3,2.7,3.5,1.8,5.9]})
print (df)
col
0 1.0
1 2.2
2 2.8
3 3.7
4 5.5
5 5.8
6 4.3
7 2.7
8 3.5
9 1.8
10 5.9

binned = pd.cut(df['col'], np.arange(1, 7), include_lowest=True)
df1 = df.groupby(binned).size().reset_index(name='val')
df1['mid'] = pd.IntervalIndex(df1['col']).mid
df1['mul'] = df1['val'].mul(df1['mid'])
print (df1)
col val mid mul
0 (0.999, 2.0] 2 1.4995 2.999
1 (2.0, 3.0] 3 2.5000 7.500
2 (3.0, 4.0] 2 3.5000 7.000
3 (4.0, 5.0] 1 4.5000 4.500
4 (5.0, 6.0] 3 5.5000 16.500

a = df1.sum()
print (a)
val 11.0000
mid 17.4995
mul 38.4990
dtype: float64

b = a['mul'] / a['val']
print (b)
3.49990909091

关于python - Pandas 中任意分布的频率均值计算,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49124855/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com