利用Python实现json格式转换为csv文件格式
前言
本文是学校的课程设计,这里我没有用封装好的json库来实现,而是把读进来的文件当一个字符串来处理,核心函数其实是python的eval()类型转换函数。
什么是 JSON?
我们要考虑到json格式下key-value对的结构是无序的。JSON:JavaScript Object Notation(JavaScript 对象表示法),是存储和交换文本信息的语法。有点类似 XML,JSON 比 XML 更小、更快,更易解析,同时删除了不必要的元素信息。
读取文件
首先读取文件数据到data_str, 这里注意文件编码,否则会出现乱码。
with
观察一下读取的json内容
print
json文件格式
- 对象可以包含多个 key/value(键/值)对。
- key 必须是字符串,value 可以是合法的 JSON 数据类型(字符串, 数字, 对象, 数组, 布尔值或 null)。
- key 和 value 中使用冒号(:)分割。
- 每个 key/value 对使用逗号(,)分割。
替换元素
对json文件做一个替换,这里这样替换是有问题的,因为从前向后扫描的时候只有在引号外的元素才需要替换,可以对扫过的引号数量取模实现。
data_str
类型函数
判断当前的字符串属于哪个类型
def
head函数的实现
遍历获得json的所有key作为csv的表头
data_head
body内容的转换
data_head_dict保存转换后CSV的body内容
data_head_dict
宽度的拓展,这里实现的时候比较暴力。解决方案如下: 1. 最后自底向上删空行 2. 处理head的时候加tag记录行号
for
看一下表的内容是否正确
for
输出CSV文件
with
以utf-8编码格式输出文件
with
5 rows × 116 columns