ホームページ > バックエンド開発 > Python チュートリアル > 私のパンダの「replace()」メソッドが単純な文字列置換に機能しないのはなぜですか?

私のパンダの「replace()」メソッドが単純な文字列置換に機能しないのはなぜですか?

Mary-Kate Olsen
リリース: 2024-11-02 09:48:02
オリジナル
567 人が閲覧しました

Why Isn't My Pandas `replace()` Method Working for Simple String Replacements?

Pandas replace() メソッドが機能しない?この簡単な修正をお試しください

replace() メソッドを使用して Pandas DataFrame 内の文字列を置換しようとすると、置換が行われないという不可解な問題が発生する可能性があります。複雑な置換とは対照的に、この状況には単純な置換の試行が含まれることがよくあります。

説明のために、次のデータフレームを調べてみましょう:

d = {'color' : pd.Series(['white', 'blue', 'orange']),
   'second_color': pd.Series(['white', 'black', 'blue']),
   'value' : pd.Series([1., 2., 3.])}
df = pd.DataFrame(d)
ログイン後にコピー

出現するすべての「white」を次のデータフレームに置換しようとすると、 NaN、驚くべきことに、何も起こりません:

df.replace('white', np.nan)
ログイン後にコピー

出力は変更されません:

      color second_color  value
0   white        white      1
1    blue        black      2
2  orange         blue      3
ログイン後にコピー

それで、何が問題だったのでしょうか?

replace() が原因であることがわかります。このメソッドはデフォルトで完全置換検索を実行します。部分置換を有効にするには、正規表現パラメータを True に設定する必要があります:

df.replace('white', np.nan, regex=True)
ログイン後にコピー

または、置換プロセスをより詳細に制御できる str.replace() メソッドを使用することもできます:

df['color'].str.replace('white', np.nan)
ログイン後にコピー

ボーナスヒント: inplace=True を使用して置換をインプレースで実行することを検討している場合は、その注意点を必ず理解してください。

以上が私のパンダの「replace()」メソッドが単純な文字列置換に機能しないのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート