「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > Pandas DataFrame で空白値 (空白) を NaN に置き換えるにはどうすればよいですか?

Pandas DataFrame で空白値 (空白) を NaN に置き換えるにはどうすればよいですか?

2024 年 11 月 8 日に公開
ブラウズ:278

How do I replace blank values (whitespace) with NaN in a Pandas DataFrame?

Pandas で空白値 (空白) を NaN に置き換える

データ クリーニングは、データ分析における重要なステップです。一般的なタスクの 1 つは、空白値 (空白) を NaN に置き換えることです。これは Pandas を使用して効率的に行うことができます。

これを実現するには、df.replace() 関数を利用します。この関数により、DataFrame 値に対する正規表現ベースの検索および置換操作が可能になります。実装方法は次のとおりです:

import numpy as np
import pandas as pd

df = pd.DataFrame([
    [-0.532681, 'foo', 0],
    [1.490752, 'bar', 1],
    [-1.387326, 'foo', 2],
    [0.814772, 'baz', ' '],
    [-0.222552, '   ', 4],
    [-1.176781,  'qux', '  '],
], columns='A B C'.split(), index=pd.date_range('2000-01-01','2000-01-06'))

# Replace fields that contain only whitespace (or are empty) with NaN
print(df.replace(r'^\s*$', np.nan, regex=True))

# Output:
#                    A    B   C
# 2000-01-01 -0.532681  foo   0
# 2000-01-02  1.490752  bar   1
# 2000-01-03 -1.387326  foo   2
# 2000-01-04  0.814772  baz NaN
# 2000-01-05 -0.222552  NaN   4
# 2000-01-06 -1.176781  qux NaN

このコードは、空白のみを含むフィールドまたは空のフィールドを置き換えることに注意してください(つまり、正規表現 r'^\s*$'** に一致します)。 。有効なデータに空白が含まれている場合は、それに応じて正規表現を調整します (たとえば、r'^\s ' の場合は末尾から **$ を削除します)。

最新のチュートリアル もっと>

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3