pandas NaN to None

当使用pandas DataFrame时,若需将NaN转换为None以适应JSON传输,需根据pandas版本采取不同策略。对于1.3.0及以上版本,可直接使用replace方法;而对于早期版本,则需借助where方法。注意在1.3.0版本后,where方法的other参数要求可调用,这可能导致版本升级后的代码错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

pandas的DataFrame取用数据十分便利,但是空值存储为NaN(np.nan),在json需转换为None进行数据传递,记录转换方法。

if version.parse(pd.__version__) >= version.parse('1.3.0'):
    df = df.replace({np.nan: None})
else:
    df = df.where(df.notnull(), None)

pandas版本高于1.3.0时,通过replace方法,置换NaN和None,replace是相互的,dataframe中的NaN会被转换为None,而其中的None会被转换为NaN。确保数据更改的一致性可以加一句:

df = df.fillna(np.nan)
df = df.replace({np.nan: None})

pandas版本低于1.3.0时,利用where方法,保留不为空的值,其他置为None。

df.where(cond, other),cond:保留项需满足的条件,other:不满足条件的用other值替换。

pandas1.3.0之后对where的other进行了调整,other的值必须是可调用的。这就很烦,之前写的代码,换个版本通通报错了,查了半天才发现函数变了😫。

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值