如何将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:
    无论是否出现异常,均执行的代码
相关推荐
2401_858286111 小时前
OS55.【Linux】理解信号量(不是信号)
linux·运维·服务器·计数器·信号量
忘忧记2 小时前
pythonQT版本的图书管理系统
python·fastapi
一只理智恩2 小时前
AI 实战应用:从“搜索式问答“到“理解式助教“
人工智能·python·语言模型·golang
Katecat996632 小时前
输液泵设备检测与识别基于改进YOLO11模型的实现详解_ETB
python
Sirius.z2 小时前
第T7周:咖啡豆识别
python
yao12497364732 小时前
【无标题】
python·synergy·deskflow·键鼠共享·hyprland·niri
workflower3 小时前
原子需求的属性
python·测试用例·需求分析·软件需求
尘缘浮梦3 小时前
协程asyncio入门案例 2
开发语言·python
kronos.荒3 小时前
滑动窗口+哈希表:最小覆盖子串
数据结构·python·散列表