[解決済み] Pandas: カテゴリを数値に変換する
2022-10-25 06:43:37
質問
例えば、以下のような国のデータフレームがあるとします。
cc | temp
US | 37.0
CA | 12.0
US | 35.0
AU | 20.0
国を'one-hot encodings'に変換するpd.get_dummies関数があることは知っています。しかし、私はそれらをインデックスに変換し、次のようなものを得たいと考えています。
cc_index = [1,2,1,3]
代わりに
私は、以下のようにnumpyのwhere句と一緒にget_dummiesを使用するよりも高速な方法があると仮定しています。
[np.where(x) for x in df.cc.get_dummies().values]
これはRで'factors'を使って行うのがいくらか簡単なので、pandasに似たようなものがあることを期待しています。
どのように解決するのですか?
まず、カラムの種類を変更します。
df.cc = pd.Categorical(df.cc)
これで、データの見た目は似ていますが、カテゴリ別に保存されるようになりました。 カテゴリコードを捕捉するために
df['code'] = df.cc.cat.codes
これで
cc temp code
0 US 37.0 2
1 CA 12.0 1
2 US 35.0 2
3 AU 20.0 0
DataFrameを修正せず、単にコードを取得したい場合。
df.cc.astype('category').cat.codes
または、カテゴリカラムをインデックスとして使用します。
df2 = pd.DataFrame(df.temp)
df2.index = pd.CategoricalIndex(df.cc)
関連
-
[解決済み] PandasでDataFrameの行を反復処理する方法
-
[解決済み] バイトを文字列に変換する
-
[解決済み] Pandasのカラム名のリネーム
-
[解決済み] Pandas DataFrameからカラムを削除する
-
[解決済み] Pandasのデータフレームで複数の列を選択する
-
[解決済み] Pandas DataFrameの行数を取得する方法は?
-
[解決済み] 既存のDataFrameに新しい列を追加する方法は?
-
[解決済み] 辞書のリストをpandasのDataFrameに変換する
-
[解決済み] pandasのデータフレームのインデックスをカラムに変換する方法
-
[解決済み】Pandas DataFrameのカラムヘッダからリストを取得する。
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み] PILからopenCVフォーマットへの変換
-
[解決済み] Djangoで2つの日付の間を選択する
-
[解決済み] データフレームをソートした後にインデックスを更新する
-
[解決済み] Django Rest Framework ファイルアップロード
-
[解決済み] 文字列のリストを内容に基づいてフィルタリングする
-
[解決済み] オブジェクトのリストに特定の属性値を持つオブジェクトが含まれているかどうかをチェックする
-
[解決済み] Ctrl-CでPythonスクリプトを終了できない
-
[解決済み] Django で全てのリクエストヘッダを取得するにはどうすれば良いですか?
-
[解決済み] matplotlib でプロットの軸、目盛、ラベルの色を変更する方法
-
[解決済み] Pythonでファイルの読み込みと上書きをする