質問するログイン新規登録

Q&A

解決済

2回答

14454閲覧

could not convert string to float:のエラーがでてしまいます

Misa

総合スコア3

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2022/03/08 11:07

編集2022/03/08 12:31

0

0

Pythonに関する質問です。
以下のような2つの数字を/でつなげている要素を含むDataFrame(data)があり、

index敷金/礼金
122.1/55.3

これを22.1と55.3に分け、足し算した値を列に加えたいです、

data['initial1'] = data['敷金/礼金'].str.split(pat='/',expand=True)[0] data['initial2'] = data['敷金/礼金'].str.split(pat='/',expand=True)[1]

でまず分けることができたのですが、ここからfloat型にするために

data['initial1'] = data['initial1'].astype(float) data['initial2'] = data['initial2'].astype(float)

を実行すると

ValueError: could not convert string to float: ''

というエラーがでてしまいます。"が邪魔しているのだと思い、

data['initial1'] = data['initial1'].replace('"','') data['initial2'] = data['initial2'].replace('"','') data['initial1'] = data['initial1'].astype(float) data['initial2'] = data['initial2'].astype(float)

を再度実行しましたが同じエラーが出てしまいます。なにか解決方法はありますでしょうか?ご教授いただければと思います。

(追記)
dataについて、敷金、礼金どちらかがない行だと
22.1/
/55.3
といった行はありました。
ですが、敷金、礼金どちらも入っているパターンで
/22.1/55.3
22.1//55.3
といったパターンはありませんでした。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

melian

2022/03/08 11:27 編集

例えば、先頭もしくは中途に / が入っている行はありませんか? /22.1/55.3 22.1//55.3 などです。
Misa

2022/03/08 12:27

melianさん、ありがとうございます。 敷金、礼金どちらかがない行だと 22.1/ /55.3 といった行はありました。 ですが、敷金、礼金どちらも入っているパターンで /22.1/55.3 22.1//55.3 といったパターンはありませんでした。
guest

回答2

0

Hi,
To solve this, you need to filter out the empty strings before attempting the conversion. We can do it like this territorial io:

python data['initial1'] = data['Deposit key money'].str.split('/', expand=True)[0] data['initial2'] = data['Deposit key money'].str.split('/', expand=True)[1] # Filter out empty strings data['initial1'] = data['initial1'].str.strip().ne('').astype(float) data['initial2'] = data['initial2'].str.strip().ne('').astype(float) The .str.strip().ne('') part will: .strip() - Remove leading and trailing whitespace .ne('') - Check if the string is not equal to '' (empty string)

So this will filter out any empty strings before attempting the float conversion.

Running this code should resolve the ValueError and successfully convert your strings to floats, ignoring any empty rows.

投稿2023/07/11 21:23

SpencerGupton

総合スコア2

0

ベストアンサー

pd.to_numeric()errors='coerce' を指定します(欠損値が NaN` になります)。

python

1import pandas as pd 2import io 3 4pd.set_option('display.unicode.east_asian_width', True) 5 6csv_data = ''' 7敷金/礼金 843.5/78.1 922.1/ 10/55.3 11''' 12data = pd.read_csv(io.StringIO(csv_data)) 13 14# 15cols = ['initial1', 'initial2'] 16data[cols] = data['敷金/礼金'].str.split(pat='/',expand=True) 17data[cols] = data[cols].apply(pd.to_numeric, errors='coerce') 18 19print(data) 20print(data.dtypes) 21 22# 23 敷金/礼金 initial1 initial2 240 43.5/78.1 43.5 78.1 251 22.1/ 22.1 NaN 262 /55.3 NaN 55.3 27 28敷金/礼金 object 29initial1 float64 30initial2 float64 31dtype: object

投稿2022/03/08 12:47

melian

総合スコア21745

Misa

2022/03/08 16:02

ありがとうございます!欠損のある列に対してはpd.to_numeric()が有効なのですね。欠損値のことを考えていませんでした、、、
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.29%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問