首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >熊猫价格栏对象int

熊猫价格栏对象int
EN

Stack Overflow用户
提问于 2017-06-10 03:50:09
回答 16查看 14.8K关注 0票数 4

我有一个名为amount的列,其包含的值如下所示:$3,092.44当我执行dataframe.dtypes()时,它作为对象返回该列,如何将该列转换为int类型?

EN

回答 16

Stack Overflow用户

回答已采纳

发布于 2017-06-10 04:24:51

在regex中,\D的意思不是数字..。所以我们可以使用pd.Series.str.replace

代码语言:javascript
复制
dataframe.amount.replace('\D', '', regex=True).astype(int)

0    309244
1    309244
Name: amount, dtype: int64
票数 14
EN

Stack Overflow用户

发布于 2017-06-10 04:16:17

可以将Series.replaceSeries.str.replaceSeries.astype结合使用。

代码语言:javascript
复制
dataframe = pd.DataFrame(data={'amount':['$3,092.44', '$3,092.44']})
print (dataframe)
      amount
0  $3,092.44
1  $3,092.44

dataframe['amount'] = dataframe['amount'].replace('[\$\,\.]', '', regex=True).astype(int)

print (dataframe)
   amount
0  309244
1  309244
代码语言:javascript
复制
dataframe['amount'] = dataframe['amount'].astype(int)

print (dataframe)
   amount
0  309244
1  309244
票数 15
EN

Stack Overflow用户

发布于 2020-01-23 09:55:42

这就是你如何做到这一点,同时也丢弃了美分:

代码语言:javascript
复制
car_sales["Price"] = car_sales["Price"].str.replace('[\$\,]|\.\d*', '').astype(int)
票数 10
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/44469313

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档