CSV格式常用于一二维数据表示和存储,是一种纯文本形式存储表格数据的表示方式。
操作文档采用python从入门到入魔第是十一天——CSV标准库的使用生成的CSV 类型的“人员信息”文件
一、CSV数据类型转JSON类型转换方式如下:

方法一:
import json
import csv
fr = open("D:/日常文件/人员信息.csv","r")
fw = open("D:/日常文件/JSON类型数据1.json","w")
dict_reader = csv.DictReader(fr)
ls = []
header = dict_reader.fieldnames
print(header) #打印第一行
for i in dict_reader:
ls.append(i)
json.dump(ls,fw,sort_keys=True,indent=4,ensure_ascii=False)
fr.close()
fw.close()
方法二:
import json
#数据读入
fr = open("D:/日常文件/人员信息.csv","r")
list = []
for line in fr:
line = line.replace("\n","")
list.append(line.split(","))
fr.close()
#数据处理,转为JSON格式,存入JSON类型数据.json文件
fw = open("D:/日常文件/JSON类型数据.json","w")
for i in range(1,len(list)):
list[i] = dict(zip(list[0],list[i]))#zip()内置函数,将两个长度相同的列表组合成一个关系对
json.dump(list[1:],fw,sort_keys=True,indent=4,ensure_ascii=False)
fw.close()
#zip函数使用
>>> x = ["a","b","c"]
>>> y = [1,2,3]
>>> print(list(zip(x,y)))#列表类型
[('a', 1), ('b', 2), ('c', 3)]
>>> print(dict(zip(x,y)))#字典类型
{'a': 1, 'b': 2, 'c': 3}
>>>
输出结果

二、JSON数据类型转CSV类型转换方式如下:
方法一:
import json
import csv
with open("D:/日常文件/JSON类型数据.json","r") as fr:
ls = json.load(fr)
with open("D:/日常文件/人员信息02.csv", "w", newline="") as fw1:
header = list(ls[0].keys()) #获取表头数据
write = csv.DictWriter(fw1,fieldnames=header)
write.writeheader() #写入表头
write.writerows(ls) #写入数据
fr.close()
fw1.close()
方法二:
import json
fr = open("D:/日常文件/JSON类型数据.json","r")
ls = json.load(fr)
data = [list(ls[0].keys())] #获取键数据并存入列表data中
for i in ls:
data.append(ls[i].values())
fr.close()
fw = open("D:/日常文件/人员信息01.csv", "w")
for i in data:
fw.write(",".join(i) + "\n")
fw.close()

本文介绍了如何在Python中将CSV文件转换为JSON文件以及将JSON文件转换回CSV文件的两种方法。通过DictReader和DictWriter实现了数据的双向转换,详细展示了使用csv和json库的步骤,适合初学者学习。

被折叠的 条评论
为什么被折叠?



