[解決済み] pandas DataFrameのカンマ付き数値文字列をfloatに変換する。
2022-09-22 14:03:12
質問
文字列として数値を含むDataFrameがあります。千のマーカーにはカンマがあります。私はそれらを浮動小数点に変換する必要があります。
a = [['1,200', '4,200'], ['7,000', '-0.03'], [ '5', '0']]
df=pandas.DataFrame(a)
locale.atofを使う必要があるのではと推測しています。確かに
df[0].apply(locale.atof)
は期待通りに動作します。私は浮動小数点数のシリーズを取得します。
しかし、DataFrameに適用すると、エラーが発生します。
df.apply(locale.atof)
TypeErrorです。("cannot convert the series to ", u'occurred at index 0').
と
df[0:1].apply(locale.atof)
は別のエラーを出します。
ValueError: ('invalid literal for float(): 1,200', u'インデックス0に発生')
では、これをどのように変換すればよいかというと
DataFrame
を浮動小数点数のDataFrameに変換するにはどうしたらよいでしょうか?
どのように解決するのですか?
もし、あなたが から読み込んでいる場合 であれば thousands arg :
df.read_csv('foo.tsv', sep='\t', thousands=',')
この方法は、操作を別の手順として実行するよりも効率的であると思われます。
あなたは ロケールを設定する を最初に設定する必要があります。
In [ 9]: import locale
In [10]: from locale import atof
In [11]: locale.setlocale(locale.LC_NUMERIC, '')
Out[11]: 'en_GB.UTF-8'
In [12]: df.applymap(atof)
Out[12]:
0 1
0 1200 4200.00
1 7000 -0.03
2 5 0.00
関連
-
[解決済み] PandasでDataFrameの行を反復処理する方法
-
[解決済み] Pandas DataFrameからカラムを削除する
-
[解決済み] 文字列が数値(float)であるかどうかを確認するにはどうすればよいですか?
-
[解決済み] Pandasのデータフレームで複数の列を選択する
-
[解決済み] Pandas DataFrameの行数を取得する方法は?
-
[解決済み] 一行ずつ追加してPandas Dataframeを作成する
-
[解決済み] コンマを桁区切りとして数字を印刷するには?
-
[解決済み] 辞書のリストをpandasのDataFrameに変換する
-
[解決済み] Pandasシリーズ/DataFrame全体をプリティプリントする
-
[解決済み】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 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み] Python 3でバイナリデータを標準出力に書き込むには?
-
[解決済み] ファブリック経由でデプロイユーザとしてvirtualenvを有効化する
-
[解決済み] 文字列のリストを内容に基づいてフィルタリングする
-
[解決済み] 範囲指定された浮動小数点数のランダムな配列を生成します。
-
[解決済み] Ctrl-CでPythonスクリプトを終了できない
-
[解決済み] subprocess.run()の出力を抑制またはキャプチャするには?
-
[解決済み] Pandasを使って、既存のExcelファイルに新しいシートを保存する方法は?
-
[解決済み] Django filter queryset __in for *every* item in list
-
[解決済み] 新しいpip backtrackingの実行時問題の解決
-
[解決済み] 認証プラグイン 'caching_sha2_password' はサポートされていません。