excel2json软件使用方法(Excel表快速转换成JSON字符串)

所属分类: 软件教程 / 编程开发 阅读数: 369
收藏 0 赞 0 分享

把Excel表单转换成json对象,并保存到一个文本文件中,并支持生成C# class数据定义代码。

把Excel表单转换成json对象,并保存到一个文本文件中。
表格格式见:ExampleData.xlsx
支持导出为数组 Json格式,每一行转换为数组的一行,结构如下: [ {行内容}, {行内容}, {...}, ]
支持导出为Dictionary Json对象, 每一行转换成一个json对象。结构如下: { ID:{行内容}, ID:{行内容}, ID:{...} }

Excel表单格式约定

第一行固定作为列名(用来构造json字段名称);
第一列固定作为对象的ID;
读取Excel Workbook中的第一个sheet;
对于SQL导出模式:第二行固定为字段类型
使用表头生成C#数据定义代码

命令行参数

-e, --excel Required. 输入的Excel文件路径.
-j, --json 指定输出的json文件路径.
-s, --sql 指定输出的SQL文件路径.
-p, --csharp 指定输出的C#数据定义代码文件路径.
-h, --header Required. 表格中有几行是表头.
-c, --encoding (Default: utf8-nobom) 指定编码的名称.
-l, --lowcase (Default: false) 自动把字段名称转换成小写格式.

例如:excel2json --excel test.xlsx --json test.json --header 3 --array true,其中的输入和输出文件,都在当前目录下;

在游戏项目中一般都需要由策划制作大量的游戏内容,其中很大一部分是使用Excel表来制作的。于是程序就需要把Excel文件转换成程序方便读取的格式。
之前项目使用的Excel表导入工具都是通过Office Excel组件来实现数据访问的,效率十分令人不满。一个端游项目一般要上百个表格,手游项目20、30个表格基本也是要的,于是表格导入程序的过程一般要几分钟,项目后期要接近半个小时。
此次分享的小工具,在速度上有质的飞越,比上述方法实现的工具有接近100倍的速度提升:
完整项目源代码下载:https://github.com/neil3d/excel2json
主要功能是:把Exce的l表单转换成json对象,并保存到一个文本文件中
使用方式是命令行式的,方便将多个表格转换工作写成一个批处理文件,一次执行完毕。
之所以能够效率提高这么多,并不是博主的编程水平有多高,而是拜另外一个开源项目所赐:https://github.com/ExcelDataReader/ExcelDataReader
这个库并没有使用Office组件,而是直接读取文件,解析其内容,绕过了复杂的组件机制、数据转换过程,所以才能如此神速。这主要是也OpenXML标准带了的好处。

顺便科普一下,Excel的xlsx文件其实是一个标准的zip文件,如下图所示。将其解压缩之后,就可以根据OpenXML标准去解析里面的xml文件了。:)最近常遇到这样的需求:把Excel表格中人员角色等数据,转换成json格式的数据,然后把json数据导入到mongodb数据库中。

在寻找快速解决办法的时候,发现一款C#写的工具,虽然不是C#开发人员,但是很好用,特此记录。

github:https://github.com/neil3d/excel2json

windows 可执行文件下载:https://www.jb51.net/softs/578020.html

使用方法

1.下载解压到文件夹,尽量不要有中文路径;
如图:
这里写图片描述

2.新建一个Excel文件,Excel表格后缀必须为xlsx。并且填入相关数据;
如图:
这里写图片描述

3.windows命令行打开,执行下面的命令:
这里写图片描述

excel2json –excel F:\order-gy.xlsx –json F:\ex.json –header 1

–excel 后面跟随Excel文件路径;–json 后面跟随转换的json文件之后保存路径;–header 后面为Excel表格中头占据多少行

4.执行结果如图:
这里写图片描述

得到的json文件稍作修改,便可直接导入mongodb数据库,也可做其他处理。

更多精彩内容其他人还在看

VisualStudio2015怎么设计一个注册信息的页面?

VisualStudio2015怎么设计一个注册信息的页面?vs2015中想要设计一个注册表信息的页面,该怎么制作填写信息的表格呢?下面我们就来看看详细的教程,需要的朋友可以参考下
收藏 0 赞 0 分享

Notepad怎么显示隐藏的字符?

Notepad怎么显示隐藏的字符?Notepad++中文件都有隐藏的字符,想要显示隐藏的字符,该怎么显示呢?下面我们就来看看详细的教程,需要的朋友可以参考下
收藏 0 赞 0 分享

VS2017怎么提交作业? VS提交作业的方法

VS2017怎么提交作业?VS2017中做编程开发的时候,想要进行作业提交,该怎么提交呢?下面我们就来看看VS提交作业的方法,需要的朋友可以参考下
收藏 0 赞 0 分享

VS2017怎么使用作业视图?

VS2017怎么使用作业视图?VS2017中想要使用作业视图,该怎么使用作业视图呢?下面我们就来看看详细的教程,需要的朋友可以参考下
收藏 0 赞 0 分享

VS2017怎么使用Web代码分析功能?

VS2017怎么使用Web代码分析功能?经常使用VS2017进行编程开发,这个软件有很多功能,今天我们就来给大家介绍Web代码分析的使用方法,需要的朋友可以参考下
收藏 0 赞 0 分享

VS2017怎么使用ADLS路径?

VS2017怎么使用ADLS路径?VS2017编程开发经常使用的软件,该怎么使用ADLS路径呢?下面我们就来看看详细的教程,需要的朋友可以参考下
收藏 0 赞 0 分享

vscode英文版怎么显示隐藏行号?

vs code英文版怎么显示隐藏行号?Visual Studio Code中编程开发的时候,想要隐藏行号,该怎么隐藏或者显示行号呢?下面我们就来看看详细的教程,需要的朋友可以参考下
收藏 0 赞 0 分享

vscode英文版怎么设置自动保存的时间?

vscode英文版怎么设置自动保存的时间?使用vscode软件的时候,为了防止意外早层的文件丢失损失,想要设置自动保存文件,下面我们就来看看详细的教程,需要的朋友可以参考下
收藏 0 赞 0 分享

Sublime怎么查看最近打开的文件?

Sublime怎么查看最近打开的文件?Sublime编程开发的时候,想要打开之前打开过的文件,该怎么操作呢?下面我们就来看看详细的教程,需要的朋友可以参考下
收藏 0 赞 0 分享

Authorware多媒体课件怎么插入背景音乐?

Authorware多媒体课件怎么插入背景音乐?Authorware制作的课件需要插入音乐,该怎么插入背景音乐呢?下面我们就来看看详细的教程,需要的朋友可以参考下
收藏 0 赞 0 分享
查看更多