1. 学ぶ
  2. /
  3. コース
  4. /
  5. Python中級

Connected

演習

列の追加(2)

iterrows()を使ってPandas DataFrameのすべての観測値を反復処理する方法は理解しやすいですが、あまり効率的ではありません。各反復で、新しいPandas Seriesを作成しているからです。

DataFrameに列を追加する際に、別の列に関数を呼び出して処理する場合、iterrows() メソッドとforループを組み合わせる方法は推奨される方法ではありません。代わりに、apply()を使いましょう。

bricsDataFrameで同じ結果を得るために、iterrows()を使ったバージョンとapply()を使ったバージョンを比較してみましょう。

for lab, row in brics.iterrows() :
    brics.loc[lab, "name_length"] = len(row["country"])

brics["name_length"] = brics["country"].apply(len)

同じように、country列のすべての名前に対してupper()メソッドを呼び出すこともできます。ただし、upper()はメソッドなので、少し違うアプローチが必要です。

指示

100 XP
  • forループを、.apply(str.upper)を使った1行のコードに置き換えましょう。この呼び出しによって同じ結果が得られるはずです。国名を大文字に変換したものを含むCOUNTRY列が、carsに追加されます。
  • いつものように、carsを出力して努力の成果を確認しましょう。