csv 字符串_Python实现json转csv格式

02f0b1f1a3efd9ed265b58adf3c87359.png

利用Python实现json格式转换为csv文件格式

前言

本文是学校的课程设计,这里我没有用封装好的json库来实现,而是把读进来的文件当一个字符串来处理,核心函数其实是python的eval()类型转换函数。

什么是 JSON?

我们要考虑到json格式下key-value对的结构是无序的。JSON:JavaScript Object Notation(JavaScript 对象表示法),是存储和交换文本信息的语法。有点类似 XML,JSON 比 XML 更小、更快,更易解析,同时删除了不必要的元素信息。

读取文件

首先读取文件数据到data_str, 这里注意文件编码,否则会出现乱码。

with 

观察一下读取的json内容

print

json文件格式

  1. 对象可以包含多个 key/value(键/值)对。
  2. key 必须是字符串,value 可以是合法的 JSON 数据类型(字符串, 数字, 对象, 数组, 布尔值或 null)。
  3. key 和 value 中使用冒号(:)分割。
  4. 每个 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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值