Welcome to OStack Knowledge Sharing Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
384 views
in Technique[技术] by (71.8m points)

python - Convert string to float pandas

Simple question: I have a dataset, imported from a csv file, containing a string column with numeric values. After the comma are decimal places.

I want to convert to float. Basically,it's just this:

x = ['27,10083']
df = pd.DataFrame(x)
df.astype(float)

Why does this not work and how to fix this simple issue?

Thanks in advance.

See Question&Answers more detail:os

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Answer

0 votes
by (71.8m points)

Assign output with replace:

df = df.replace(',','.', regex=True).astype(float)

If want specify columns for converting:

cols = ['col1','col2']
df[cols] = df[cols].replace(',','.', regex=True).astype(float)

Another solution is use parameter decimal=',' in read_csv, then columns are correctly parsed to floats:

df = pd.read_csv(file, decimal=',')

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome to OStack Knowledge Sharing Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

...