首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >仅更新到期日期大于python max date - 2261的行-无法将浮点型NaN转换为整数

仅更新到期日期大于python max date - 2261的行-无法将浮点型NaN转换为整数
EN

Stack Overflow用户
提问于 2018-05-28 18:30:47
回答 1查看 36关注 0票数 1

我希望更新任何晚于Python的最大日期的日期:

代码语言:javascript
复制
display(df['maturity_date'].dtypes)

dtype('O')

display(df['maturity_date'].describe())

count                    3488
unique                    766
top       2166-09-23 00:00:00
freq                      130
Name: maturity_date, dtype: object


m = df['maturity_date'].str[:4].astype(int) > 2261

ValueError: cannot convert float NaN to integer

在这种情况下,似乎没有错误,所以这是引发错误的原因吗?我如何才能使Pandas仅在条件为真时才更新?最好是抑制错误还是处理它?

代码语言:javascript
复制
df['maturity_date'] = df['maturity_date'].mask(m, '2261' + df['maturity_date'].str[4:]) # for all dates greater than python max date replace
df['maturity_date'] = pd.to_datetime(df['maturity_date']) 
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-05-28 18:32:30

我认为需要转换为float,因为缺少的NaNs或Nones的值具有类型float,因为在pandas中不可能根据设计将NaNs转换为int

代码语言:javascript
复制
m = df['maturity_date'].str[:4].astype(float) > 2261

另一种解决方案是首先使用NaNs或Nones删除行:

代码语言:javascript
复制
df = df.dropna(subset=['maturity_date'])

对于检查有问题的行,请使用:

代码语言:javascript
复制
df = df[df['maturity_date'].isnull()]
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50564331

复制
相关文章

相似问题

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