首頁 > 後端開發 > Python教學 > 如何用列平均值替換 Pandas DataFrame 中的 NaN 值?

如何用列平均值替換 Pandas DataFrame 中的 NaN 值?

Linda Hamilton
發布: 2024-10-30 07:01:28
原創
192 人瀏覽過

How to Replace NaN Values in a Pandas DataFrame with Column Averages?

Pandas DataFrame:以列平均值取代 NaN 值

在 pandas DataFrame 中,處理缺失資料對於準確分析至關重要。當遇到不完整的資料時,有必要用有意義的估計值來取代 NaN 值。本文示範如何以 pandas DataFrame 中各自列的平均值取代 NaN 值。

問題

考慮一個混合有實數和 NaN 值的 DataFrame。目標是將 NaN 值替換為它們出現的列的平均值。

與NumPy 陣列不同,在pandas DataFrame 中填入NaN 值可以使用fillna 方法:

<code class="python">df.fillna(df.mean())</code>
登入後複製

此方法用對應列的平均值填入NaN值。例如:

<code class="python">df = pd.DataFrame({'A': [-0.166919, -0.297953, -0.120211, np.nan, np.nan, -0.788073, -0.916080, -0.887858, 1.948430, 0.019698],
                   'B': [0.979728, -0.912674, -0.540679, -2.027325, np.nan, np.nan, -0.612343, 1.033826, 1.025011, -0.795876],
                   'C': [-0.632955, -1.365463, -0.680481, 1.533582, 0.461821, np.nan, np.nan, np.nan, -2.982224, -0.046431]})

mean = df.mean()
print(df.fillna(mean))</code>
登入後複製

輸出:

          A         B         C
0 -0.166919  0.979728 -0.632955
1 -0.297953 -0.912674 -1.365463
2 -0.120211 -0.540679 -0.680481
3 -0.151121 -2.027325  1.533582
4 -0.151121 -0.231291  0.461821
5 -0.788073 -0.231291 -0.530307
6 -0.916080 -0.612343 -0.530307
7 -0.887858  1.033826 -0.530307
8  1.948430  1.025011 -2.982224
9  0.019698 -0.795876 -0.046431
登入後複製

NaN 值已替換為其各自欄位的平均值。

以上是如何用列平均值替換 Pandas DataFrame 中的 NaN 值?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板