weixin_52664663 2022-06-12 20:11 采纳率: 66.7%
浏览 31
已结题

python中json类型相关的错误

问题遇到的现象和发生背景

将excel的数据导入,并想用echarts进行可视化,出现了错误

问题相关代码,请勿粘贴截图

class MyEncoder(json.JSONEncoder):
def default(self, obj):
if isinstance(obj, bytes):
return str(obj, encoding='utf-8')
return json.JSONEncoder.default(self, obj)

@app.route('/')
def get_data():
# 读取excel数据
import pandas as pd
io=r'C:\Users\86137\Desktop\python\2020水资源.xlsx'
work_book = pd.read_excel(io,sheet_name=0,index_col=[0],usecols=[0,4],skiprows=[0,1,2,3,4])
category=work_book.index
value = work_book.values
data={'category':category,'value':value}
return json.dumps(data,ensure_ascii=False,cls=MyEncoder, indent=4)

运行结果及报错内容

TypeError: Object of type Index is not JSON serializable

我的解答思路和尝试过的方法

添加了MyEncoder,但还是同样的错误

我想要达到的结果
  • 写回答

2条回答 默认 最新

  • 天际的海浪 2022-06-12 20:44
    关注

    work_book.index 和 work_book.value 是 pandas中的对象是不能用json.dumps()转为json字符串的
    要用.tolist()转成列表才行

    category=work_book.index.tolist()
    value = work_book.values.tolist()
    data={'category':category,'value':value}
    

    如有帮助,请点击我的回答下方的【采纳该答案】按钮帮忙采纳下,谢谢!

    img

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 6月21日
  • 已采纳回答 6月13日
  • 创建了问题 6月12日

悬赏问题

  • ¥15 stm32开发clion时遇到的编译问题
  • ¥15 lna设计 源简并电感型共源放大器
  • ¥15 如何用Labview在myRIO上做LCD显示?(语言-开发语言)
  • ¥15 Vue3地图和异步函数使用
  • ¥15 C++ yoloV5改写遇到的问题
  • ¥20 win11修改中文用户名路径
  • ¥15 win2012磁盘空间不足,c盘正常,d盘无法写入
  • ¥15 用土力学知识进行土坡稳定性分析与挡土墙设计
  • ¥70 PlayWright在Java上连接CDP关联本地Chrome启动失败,貌似是Windows端口转发问题
  • ¥15 帮我写一个c++工程