[解決済み] pandasのデータフレームでカスタムソートする
2022-05-16 08:36:40
質問
Python pandasのdataframeがあり、その中の列は月の名前を含んでいます。
どのように私は、例えば、辞書を使用して、カスタムの並べ替えを行うことができます。
custom_dict = {'March':0, 'April':1, 'Dec':3}
どのように解決するのですか?
Pandas 0.15を導入しました。 カテゴリカルシリーズ を導入し、より明確な方法でこれを行うことができるようになりました。
まず、月の列をカテゴリカルにし、使用する順序を指定します。
In [21]: df['m'] = pd.Categorical(df['m'], ["March", "April", "Dec"])
In [22]: df # looks the same!
Out[22]:
a b m
0 1 2 March
1 5 6 Dec
2 3 4 April
これで、月の列をソートすると、そのリストに関してソートされます。
In [23]: df.sort_values("m")
Out[23]:
a b m
0 1 2 March
2 3 4 April
1 5 6 Dec
注意:値がリストにない場合はNaNに変換されます。
興味のある人のための古い答え...
中間シリーズを作成して
set_index
をその上に置く。
df = pd.DataFrame([[1, 2, 'March'],[5, 6, 'Dec'],[3, 4, 'April']], columns=['a','b','m'])
s = df['m'].apply(lambda x: {'March':0, 'April':1, 'Dec':3}[x])
s.sort_values()
In [4]: df.set_index(s.index).sort()
Out[4]:
a b m
0 1 2 March
1 3 4 April
2 5 6 Dec
コメントされているように、新しいpandasでは、Seriesに
replace
メソッドがあり、これをよりエレガントに行うことができます。
s = df['m'].replace({'March':0, 'April':1, 'Dec':3})
わずかな違いは、辞書の外に値がある場合、これは発生しないことです(それはそのままです)。
関連
-
[解決済み] PandasでDataFrameの行を反復処理する方法
-
[解決済み] Pandasのカラム名のリネーム
-
[解決済み] モジュールの関数名(文字列)を使って、モジュールの関数を呼び出す。
-
[解決済み] Pythonでオブジェクトが属性を持つかどうかを知る方法
-
[解決済み] Pandas DataFrameからカラムを削除する
-
[解決済み] 既存のDataFrameに新しい列を追加する方法は?
-
[解決済み】Pandas DataFrameのカラムヘッダからリストを取得する。
-
[解決済み】pandasでカラムの種類を変更する
-
[解決済み】2つの辞書を1つの式でマージする(辞書の和をとる)には?)
-
[解決済み] 関数が受け取るキーワード引数をリストアップできますか?
最新
-
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 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み] 2つの線分が交差しているかどうかを確認するにはどうすればよいですか?
-
[解決済み] Celeryでタスクのステータスを確認するには?
-
[解決済み] ネストしたdictからのPythonデータクラス
-
[解決済み] asyncio.ensure_future vs. BaseEventLoop.create_task vs. simple coroutine?
-
[解決済み] IPythonの終了確認を無効にする
-
[解決済み] Pythonで文字列が数字で始まるかどうかを判断するには?
-
[解決済み] pathlib.Pathオブジェクトの絶対パスを取得するには?
-
[解決済み] 標準のjsonモジュールでfloatをフォーマットする
-
[解決済み] 乱数の行列を作成する簡単な方法
-
[解決済み] sqlalchemy の declarative ORM 拡張機能で複数カラムのインデックスを使用する場合