解决dataframe中放到web返回中包含nan和inf导致json序列化报错的问题

本文介绍如何在处理Pandas DataFrame中的缺失值NaN和无穷大值inf时,避免序列化失败。通过使用`to_json`方法转换并解析,将这些特殊值转换为可序列化的null和null,简化前端处理。

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

问题描述

你有个df,里面的数据可能包含NaNinf等值,要放到json结构体中然后json序列化之后返回给web前端处理

import numpy as np
import pandas as pd


df = pd.DataFrame({"a": [None, np.nan], "b": [2, np.inf]})

print(df)

结构像这样

    a    b
0 NaN  2.0
1 NaN  inf

一般是将df转换为records格式放到返回的结构体中,dumps之后返回:

import numpy as np
import pandas as pd


df = pd.DataFrame({"a": [None, np.nan], "b": [2, np.inf]})

data = df.to_dict(orient="records")
resp = json.dumps({"code": 200, "data": data})
print(resp)

这个结构

{"code": 200, "data": [{"a": NaN, "b": 2.0}, {"a": NaN, "b": Infinity}]}

会在传到前端后会序列化失败

解决方法

实际上,与其做一些各种操作把nan、inf等不合法的字符替换(顺便可能带回一些副作用,比如数值列的nan是无法替换为None的),使用df的to_json方法转换为json之后在解json序列化就能很方便快捷地解决这个问题:

import json

import numpy as np
import pandas as pd


df = pd.DataFrame({"a": [None, np.nan], "b": [2, np.inf]})
df_js = df.to_json(orient="records")
data = json.loads(df_js)
resp = json.dumps({"code": 200, "data": data})
print(resp)

输出

{"code": 200, "data": [{"a": null, "b": 2.0}, {"a": null, "b": null}]}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值