使用python对excle和json互相转换的示例
Python  /  管理员 发布于 7年前   170
python 版本:2.7
只是读取excel的话可以直接使用xlrd
1、excle to json
代码如下
# -*-coding:utf8 -*-import xlrdfrom collections import OrderedDictimport jsonimport codecsfile_name=raw_input('请输入要转换的excle文件路径:')wb = xlrd.open_workbook(file_name)dict_list = []sh = wb.sheet_by_index(0)title = sh.row_values(0)for rownum in range(1, sh.nrows): rowvalue = sh.row_values(rownum) single = OrderedDict() for colnum in range(0, len(rowvalue)): print(title[colnum], rowvalue[colnum]) single[title[colnum]] = rowvalue[colnum] dict_list.append(single) j = json.dumps(dict_list)with codecs.open(file_name[:-5]'.json',"w","utf-8") as f: f.write(j)
2、json to excle
代码如下
注意:标题会写在最后一行,主要针对字段不同的json数据。
import jsonimport osfrom openpyxl import Workbookwb = Workbook()ws = wb.activecols = []def json2excel(jsfile, excfile):# 读取json数据a = 1if os.path.exists(jsfile):with open(jsfile, 'r') as fp:while True:line = fp.readline()if not line:breakjsdata = json.loads(line)for k in jsdata.keys():if k not in cols:cols.append(k)rowdata = []for col in cols:rowdata.append(jsdata.get(col))print '正在写入的行数:'aws.append(rowdata) # 写行a += 1ws.append(cols) # 标题print('保存中')wb.save(excfile) # 保存if __name__ == '__main__':import sysif len(sys.argv) == 3:jsfile = sys.argv[1]excfile = sys.argv[2]json2excel(jsfile, excfile)else:print("Usage: python writeExc.py xx.json xx.xlsx")
以上这篇使用python对excle和json互相转换的示例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号