如何将json文件转成csv文件(python代码实操)

【将json文件转为csv文件】

开始文件格式如下:student_list.json

python 复制代码
[{"name":"赵甲","gender":"男","height":1.65,"weight":60,"stu_id":"2018312201","school":"信息","major":"信息管理"}
,{"name":"钱乙","gender":"女","height":1.75,"weight":70,"stu_id":"2018312202","school":"金融","major":"金融学"}
,{"name":"孙丙","gender":"男","height":1.85,"weight":80,"stu_id":"2018312203","school":"金融","major":"金融工程"}
,{"name":"李丁","gender":"女","height":1.95,"weight":90,"stu_id":"2018312204","school":"会计","major":"财务会计"}
,{"name":"周戊","gender":"男","height":1.65,"weight":60,"stu_id":"2018312205","school":"财政","major":"财政学"}
,{"name":"吴己","gender":"女","height":1.75,"weight":70,"stu_id":"2018312206","school":"税务","major":"税收学"}
,{"name":"郑庚","gender":"男","height":1.85,"weight":80,"stu_id":"2018312207","school":"保险","major":"保险学"}
,{"name":"王辛","gender":"女","height":1.65,"weight":60,"stu_id":"2018312208","school":"统数","major":"统计学"}
,{"name":"冯壬","gender":"男","height":1.75,"weight":70,"stu_id":"2018312209","school":"经济","major":"经济学"}
,{"name":"陈癸","gender":"女","height":1.85,"weight":80,"stu_id":"2018312210","school":"文传","major":"视觉传达"}]

目标文件格式如下:student_list2.csv

python 复制代码
name,gender,height,weight,stu_id,school,major
赵甲,男,1.65,60,2018312201,信息,信息管理
钱乙,女,1.75,70,2018312202,金融,金融学
孙丙,男,1.85,80,2018312203,金融,金融工程
李丁,女,1.95,90,2018312204,会计,财务会计
周戊,男,1.65,60,2018312205,财政,财政学
吴己,女,1.75,70,2018312206,税务,税收学
郑庚,男,1.85,80,2018312207,保险,保险学
王辛,女,1.65,60,2018312208,统数,统计学
冯壬,男,1.75,70,2018312209,经济,经济学
陈癸,女,1.85,80,2018312210,文传,视觉传达

运行python代码,将student_list.json文件中的json转成csv文件格式并保存到student_list2.csv文件中。

python 复制代码
import csv
import json

"""把json改写成csv"""

try:
    jsonname="student_list.json"
    f=open(jsonname,mode='r',encoding='utf-8')
except FileNotFoundError as e:
    print("Can not open file %s."%jsonname)
    exit()

try:
    csvname="student_list2.csv"
    f1=open(csvname,'w',newline='',encoding='utf-8')
except FileNotFoundError as e:
    print("Can not open file %s."%jsonname)
    exit()

student_list=json.load(f)
w=csv.writer(f1)

w.writerow(student_list[0].keys())
for each in student_list:
    w.writerow(each.values())

f.close()
f1.close()

上述代码中增加了try-except异常处理,如果出现FileNotFoundError的错误,就提示Can not open file 文件名。

运行成功后,会出现新文件student_list2.csv,内容如下图:

【补充常见的异常处理Exception】

1、AssertionError:断言语句失败

当assert这个关键字后边的条件为假时,程序将停止并抛出AssertionError异常。

2、AttributeError:尝试访问未知的对象属性

当访问的对象属性不存在时抛出异常。

3、IndexError:索引超出序列的范围

当索引超出序列范围的时候抛出IndexError异常。

4、KeyError:字典中查找一个不存在的关键字

当试图在字典中查找一个不存在的关键字时,就会抛出KeyError异常。

5、NameError:尝试访问一个不存在的变量

当试图访问一个不存在的变量时,会抛出NameError异常。

6、OSError:操作系统产生的异常

例如,打开一个不存在的文件就会引发FileNotFoundError,而这个FileNotFoundError就是OSError的子类

7、SyntaxError:Python的语法错误

如果程序有语法错误,就会引发SyntaxError异常,程序员应该尽力找到错误并改正。

8、TypeError:不同类型间的无效操作

不同类型的变量之间不能进行计算,否则会抛出TypeError异常。

9、ZeroDivisionError:除数为零

任何数除以零都会引发ZeroDivisionError异常。

【异常处理格式】

python 复制代码
try:
    检测范围
except Exception[as reason]:
    出现异常(Exception)后的处理代码
else:
    不出现异常的处理代码
finally:
    无论是否出现异常,均执行的代码
相关推荐
Islucas几秒前
Claude code入门保姆级教程
python·bash·claude
萝卜白菜。10 分钟前
TongWeb7.0相同的类指明加载顺序
开发语言·python·pycharm
赵钰老师19 分钟前
【ADCIRC】基于“python+”潮汐、风驱动循环、风暴潮等海洋水动力模拟实践技术应用
python·信息可视化·数据分析
爬山算法33 分钟前
MongoDB(80)如何在MongoDB中使用多文档事务?
数据库·python·mongodb
YuanDaima20481 小时前
基于 LangChain 1.0 的检索增强生成(RAG)实战
人工智能·笔记·python·langchain·个人开发·langgraph
zzzsde2 小时前
【Linux】库的制作和使用(3)ELF&&动态链接
linux·运维·服务器
CQU_JIAKE2 小时前
4.3【A]
linux·运维·服务器
RopenYuan2 小时前
FastAPI -API Router的应用
前端·网络·python
AI周红伟2 小时前
OpenClaw是什么?OpenClaw能做什么?OpenClaw详细介绍及保姆级部署教程-周红伟
大数据·运维·服务器·人工智能·微信·openclaw
听风吹等浪起2 小时前
用Python和Pygame从零实现坦克大战
开发语言·python·pygame