一个基于C#开发的Excel转Json工具
liuian 2025-03-10 18:11 4 浏览
Json在程序开发中是非常常用的数据格式,对于程序员来说,阅读和编辑Json都没有什么问题,但其他人就不是那么方便了。比如配置游戏数据:游戏角色、技能、道具的名称,策划书往往都是通过Excel配置,这样比较方便设置。但在程序运行时就需要Excel转为Json。
项目简介
这是一个基于C#开发的Excel转Json工具,比通过Office Excel组件访问数据性能提升100倍,支持界面、命令模式。
技术架构
1、Visual Studio 2012、.Net Framework 4.0
项目结构
主要功能
- 支持读取 Excel 97-2003的 .xls格式和2007的 .xlsx格式;
- 支持多个表单导出;
- 把Excel表单转换成Json对象,并保存到一个文本文件中。支持将表中内容转换成Array,或者以第一列为ID的字典对象;
- 将表头信息生成 C# 结构体定义代码;
- 进阶特性
- 通过特定的前缀排除掉表单或者列
- 自动识别和转换单元格内的 Json 格式字符串,并转换成为 Json Array 或者 Json Object
使用方式
支持命令模式与界面操作模式
1、命令模式
命令行参数
- -e, –excel Required. 输入的Excel文件路径.
- -j, –json 指定输出的json文件路径.
- -h, –header Required. 表格中有几行是表头.
- -c, –encoding (Default: utf8-nobom) 指定编码的名称.
- -l, –lowcase (Default: false) 自动把字段名称转换成小写格式.
- -a 序列化成数组
- -d, --date:指定日期格式化字符串,例如:dd / MM / yyy hh: mm:ss
- -s 序列化时强制带上sheet name,即使只有一个sheet
- -exclude_prefix: 导出时,排除掉包含指定前缀的表单和列,例如:-exclude_prefix #
- -cell_json:自动识别单元格中的Json对象和Json数组,Default:false
@SET EXCEL_FOLDER=.\excel
@SET JSON_FOLDER=.\json
@SET EXE=.\excel2json.exe
@ECHO Converting excel files in folder %EXCEL_FOLDER% ...
for /f "delims=" %%i in ('dir /b /a-d /s %EXCEL_FOLDER%\*.xlsx') do (
@echo processing %%~nxi
@CALL %EXE% --excel %EXCEL_FOLDER%\%%~nxi --json %JSON_FOLDER%\%%~ni.json --header 3
)
2、界面模式
源码与安装包获取
私信回复:1038
相关推荐
- SQL Server数据库常用命令(建议收藏)
-
创建数据库:命令:createdatabase数据库名;示例:createdatabasestudent;删除数据库:命令:dropdatabase数据库名;示例:dropdatabas...
- SQL 语句大全
-
一、基础1、说明:创建数据库CREATEDATABASEdatabase-name2、说明:删除数据库dropdatabasedbname3、说明:备份sqlserver---创建备份数...
- SQL执行顺序(SqlServer)
-
学习SQL这么久,如果突然有人问你SQL的执行顺是怎么样的?是不是很多人会觉得C#、JavaScript都是根据编程顺序来处理的,那么SQL也是根据编程顺序来执行的吗?No.SQL不同于其它编程语言...
- SQL SERVER中的group by 分组查询和having字句
-
一、groupby分组查询1、已知如下数据:2、用groupby进行分组统计根据某一列分组,同时统计多种信息3、下列这种情况是错误的:4、那么要使上诉查询成立,就必须在groupby后...
- 聊一聊SQL Server中的Row_Number
-
排序函数提供了一个非常好的特性,即在SQL中为结果集中的记录分配编号。SQL中的Row_Number是其中一个函数,它允许我们为结果集数据的行分配排名或编号。根据使用的排序函数的类型,将不同的值分配给...
- NodeJs安装和环境配置(Windows安装包方式)
-
1、官网下载https://nodejs.org/en/download/根据自己电脑系统及位数选择,我的电脑是Windows系统、64位、想下载稳定版的.msi(LTS为长期稳定版)这里选择wind...
- 与 AI 的斗智斗勇:从 npm 到 pnpm 的迁移之旅(AI 润色后的内容)
-
与AI的斗智斗勇:从npm到pnpm的迁移之旅最近听说pnpm是个好东西,能节约内存资源,简直是程序员的福音。于是我心血来潮,决定把当前项目的包管理工具从npm改成pnpm。毕竟...
- 2021 年 Node.js 开发人员学习路线图
-
Node.js自发布以来,已成为业界重要破局者之一。Uber、Medium、PayPal和沃尔玛等大型企业,纷纷将技术栈转向Node.js。Node.js支持开发功能强大的应用,例如实时追踪...
- 零基础小白也能学会!手把手教你用Electron打包网页为桌面应用
-
一、引言Electron是一款由GitHub开发的开源框架,允许开发者使用HTML、CSS和JavaScript构建跨平台的桌面应用程序。无论你是Web开发者,还是想将现有网页项目转...
- 在 Windows上安装 Node.js 开发环境的完整指南
-
在Windows上安装Node.js开发环境的完整指南一、安装Node.js和npm下载Node.js安装包访问官网Node.js—在任何地方运行JavaScript下载...
- 带你一步步搭建一个 Node.js 服务器
-
爱学习的小伙伴们,Node.js服务器有听说过没,是否觉得陌生?如此,就一起动手搭建一个吧。会的小伙伴可以略过哟~以下是搭建Node.js服务器的详细步骤:1.安装Node.js和npm...
- 小白都看得懂的Vue3.0语法教程-01-框架搭建
-
开发环境编辑器推荐:VisualStudioCode+Volar扩展检查node:vue3.0推荐node16以上node-v//查看node版本号npm-v//查看npm版本...
- pc端微信用户图片DAT格式解码为图片
-
电脑越来越慢,发现硬盘空间被大量占用,发现是微信自己账号下的Image文件夹引起的,因不清楚里面的图片有些是否有用,想清理一下。会代码的朋友可以看一下代码,自己做一下。不会代码的朋友可以看一下最后的结...
- 微信小程序分享功能
-
由于小程序的分享(微信、头条平台),需要监听页面的onShareAppMessage生命周期,小程序需要在页面声明了此生命周期,点击右上角的"胶囊"才会有分享功能,而一般情况下,我们希...
- SpringBoot+Uniapp实战开发全新仿抖音短视频App(完结)
-
历经实战检验的千万级流量架构:SpringBoot微服务集群支撑日活百万用户,Uniapp跨端方案实现秒级视频发布,智能推荐算法200毫秒内精准响应,多级缓存与混合存储体系保障99.99%高可用性,M...
- 一周热门
-
-
Python实现人事自动打卡,再也不会被批评
-
Psutil + Flask + Pyecharts + Bootstrap 开发动态可视化系统监控
-
一个解决支持HTML/CSS/JS网页转PDF(高质量)的终极解决方案
-
再见Swagger UI 国人开源了一款超好用的 API 文档生成框架,真香
-
【验证码逆向专栏】vaptcha 手势验证码逆向分析
-
网页转成pdf文件的经验分享 网页转成pdf文件的经验分享怎么弄
-
C++ std::vector 简介
-
python使用fitz模块提取pdf中的图片
-
《人人译客》如何规划你的移动电商网站(2)
-
Jupyterhub安装教程 jupyter怎么安装包
-
- 最近发表
- 标签列表
-
- python判断字典是否为空 (50)
- crontab每周一执行 (48)
- aes和des区别 (43)
- bash脚本和shell脚本的区别 (35)
- canvas库 (33)
- dataframe筛选满足条件的行 (35)
- gitlab日志 (33)
- lua xpcall (36)
- blob转json (33)
- python判断是否在列表中 (34)
- python html转pdf (36)
- 安装指定版本npm (37)
- idea搜索jar包内容 (33)
- css鼠标悬停出现隐藏的文字 (34)
- linux nacos启动命令 (33)
- gitlab 日志 (36)
- adb pull (37)
- table.render (33)
- uniapp textarea (33)
- python判断元素在不在列表里 (34)
- python 字典删除元素 (34)
- react-admin (33)
- vscode切换git分支 (35)
- vscode美化代码 (33)
- python bytes转16进制 (35)