Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
397 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 Reply

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=',')

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
OGeek|极客中国-欢迎来到极客的世界,一个免费开放的程序员编程交流平台!开放,进步,分享!让技术改变生活,让极客改变未来! Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

...