C#将Excel表导出为json文件
作者:追风剑情 发布于:2018-5-26 12:07 分类:C#
示例:Excel表导出为json文件
需要引用两个文件
using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Windows.Forms; using System.Diagnostics; using System.IO; //文档 https://docs.microsoft.com/zh-cn/previous-versions/7fzyhc74%28v%3dvs.110%29 //引用 C:\Windows\assembly\Microsoft.Office.Tools.Excel.v9.0.dll //引用COM Interop.Microsoft.Office.Interop.Excel.dll using Excel = Microsoft.Office.Interop.Excel; namespace ExcelTool { public partial class MainForm : Form { private string configPath; public MainForm() { InitializeComponent(); Init(); } private void Init() { this.AllowDrop = true; //允许文件拖入窗口 this.Load += MainForm_Load; this.DragEnter += MainForm_DragEnter; this.btnBrowser.MouseUp += btnBrowser_MouseUp; this.btnExportJson.MouseUp += btnExportJson_MouseUp; } private void MainForm_Load(object sender, EventArgs e) { Console.WriteLine("MainForm_Load"); } private void MainForm_DragEnter(object sender, DragEventArgs e) { //获取拖进来的文件路径 configPath = ((System.Array)e.Data.GetData(DataFormats.FileDrop)).GetValue(0).ToString(); this.textBoxPath.Text = configPath; } private void btnBrowser_MouseUp(object sender, MouseEventArgs e) { ShowOpenFileDialog(); this.textBoxPath.Text = configPath; } private void btnExportJson_MouseUp(object sender, MouseEventArgs e) { if (string.IsNullOrWhiteSpace(configPath)) { MessageBox.Show("请先选择要导出的excel文件", "提示"); return; } ExportJson(); } private void ShowOpenFileDialog() { //打开选择文件对话框 OpenFileDialog file = new OpenFileDialog(); file.Filter = "Excel(*.xlsx)|*.xlsx|Excel(*.xls)|*.xls"; file.InitialDirectory = Environment.GetFolderPath(Environment.SpecialFolder.Desktop); file.Multiselect = false; if (file.ShowDialog() == DialogResult.Cancel) return; //判断文件后缀 var path = file.FileName; string fileSuffix = System.IO.Path.GetExtension(path); if (string.IsNullOrEmpty(fileSuffix)) return; switch (fileSuffix) { case ".xls": //Excel 97-2003 break; case ".xlsx": //Excel 2007-更高 break; } configPath = path; } private void ExportJson() { //创建应用 Excel.Application xlApp = (Excel.Application)(new Excel.ApplicationClass()); if (xlApp == null) { MessageBox.Show("不能访问Excel"); return; } //判断使用的Excel版本 if (Convert.ToDouble(xlApp.Version) < 12) { //Excel 97-2003 } else { //Excel 2007-更高 } xlApp.Visible = false; xlApp.UserControl = true; object missing = System.Reflection.Missing.Value; //以只读方式打开文件 Excel.Workbook wb = xlApp.Application.Workbooks.Open(configPath, missing, true, missing, missing, missing, missing, missing, missing, true, missing, missing, missing, missing, missing); //获取所有工作表 Excel.Sheets sheets = wb.Worksheets; Excel.Worksheet worksheet; for (int i = 1; i <= sheets.Count; i++) { worksheet = (Excel.Worksheet)sheets[i]; //构造json string json = BuildJson(worksheet); //保存文件 SaveJson(worksheet.Name, json); } xlApp.Quit(); xlApp = null; //关掉excel进程 Process[] procs = Process.GetProcessesByName("excel"); foreach (Process pro in procs) { pro.Kill(); } GC.Collect(); MessageBox.Show("导出成功"); } private void SaveJson(string fileName, string jsonStr) { string path = string.Format("{0}/{1}.txt", Path.GetDirectoryName(configPath), fileName); File.WriteAllText(path, jsonStr); } private string BuildJson(Excel.Worksheet sheet) { if (null == sheet) return ""; //获取行数、列数 int usedRowCount = sheet.UsedRange.Cells.Rows.Count; int usedColumnCount = sheet.UsedRange.Cells.Columns.Count; string[] COLUMN_LETTER = new string[]{ "A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z"}; string C = COLUMN_LETTER[usedColumnCount - 1]; //获取数据类型定义区(即,第二行) Excel.Range typeRange = sheet.Cells.get_Range("A2", C + "2"); object[,] typeValue2 = (object[,])typeRange.Value2; //获取key定义区(即,第三行) Excel.Range keyRange = sheet.Cells.get_Range("A3", C + "3"); object[,] keyValue2 = (object[,])keyRange.Value2; //获取数据区(即,排除标题行) Excel.Range dataRange = sheet.Cells.get_Range("A4", C + usedRowCount); object[,] value2 = (object[,])dataRange.Value2; StringBuilder sb = new StringBuilder(); sb.AppendLine("["); string type, k, v; for (int i = 1; i <= dataRange.Rows.Count; i++) { //遍历时跳过ID为空的行 if (null == value2[i, 1]) continue; v = value2[i, 1].ToString(); if (string.IsNullOrWhiteSpace(v)) continue; //构造json串 sb.Append("{"); for (int j = 1; j <= dataRange.Columns.Count; j++) { k = keyValue2[1, j].ToString(); if (value2[i, j] == null) v = ""; else v = value2[i, j].ToString(); type = typeValue2[1, j].ToString(); switch(type) { case "int": sb.AppendFormat("\"{0}\":{1}", k, v); break; case "int[]": sb.Append(ParseIntArray(k, v)); break; case "json": sb.Append(ParseJson(k, v)); break; case "string": sb.AppendFormat("\"{0}\":\"{1}\"", k, v); break; case "string[]": sb.Append(ParseStringArray(k, v)); break; } if (j < dataRange.Columns.Count) sb.Append(","); } sb.Append("}"); if (i < dataRange.Rows.Count) sb.AppendLine(","); } sb.AppendLine(); sb.Append("]"); return sb.ToString(); } private string ParseIntArray(string k, string v) { string format = "\"{0}\":[{1}]"; if (string.IsNullOrWhiteSpace(v)) { return string.Format(format, k, ""); } return string.Format("\"{0}\":[{1}]", k, v); } private string ParseStringArray(string k, string v) { string format = "\"{0}\":[{1}]"; if (string.IsNullOrWhiteSpace(v)) { return string.Format(format, k, ""); } StringBuilder sb = new StringBuilder(); string[] strArr = v.Split(','); int len = strArr.Length; for (int i=0; i<len; i++) { sb.AppendFormat("\"{0}\"", strArr[i]); if (i < len - 1) sb.Append(","); } return string.Format(format, k, sb.ToString()); } private string ParseJson(string k, string v) { if (string.IsNullOrWhiteSpace(v)) return string.Format("\"{0}\":{{}}", k); return string.Format("\"{0}\":{1}", k, v); } } }
运行效果
导出文件截图
解决方法
设置嵌入互操作类型为False
如果在C:\Windows下没找到Microsoft.Office.Interop.Excel.dll还可用用NuGet安装
通过NuGet安装Microsoft.Office.Interop.Excel
注意:如果选择的版本与电脑上安装的Excel版本不匹配,运行时会报错,此时只需重新安装下其他版本方可解决。我电脑上安装的是Excel2010,这里我安装的Microsoft.Office.Interop.Excel版本为12,经亲测完美运行。
标签: C#
« 向量与矩阵的乘法
|
搭建开发环境(TS代码编译器)»
日历
最新文章
随机文章
热门文章
分类
存档
- 2024年11月(3)
- 2024年10月(5)
- 2024年9月(3)
- 2024年8月(3)
- 2024年7月(11)
- 2024年6月(3)
- 2024年5月(9)
- 2024年4月(10)
- 2024年3月(11)
- 2024年2月(24)
- 2024年1月(12)
- 2023年12月(3)
- 2023年11月(9)
- 2023年10月(7)
- 2023年9月(2)
- 2023年8月(7)
- 2023年7月(9)
- 2023年6月(6)
- 2023年5月(7)
- 2023年4月(11)
- 2023年3月(6)
- 2023年2月(11)
- 2023年1月(8)
- 2022年12月(2)
- 2022年11月(4)
- 2022年10月(10)
- 2022年9月(2)
- 2022年8月(13)
- 2022年7月(7)
- 2022年6月(11)
- 2022年5月(18)
- 2022年4月(29)
- 2022年3月(5)
- 2022年2月(6)
- 2022年1月(8)
- 2021年12月(5)
- 2021年11月(3)
- 2021年10月(4)
- 2021年9月(9)
- 2021年8月(14)
- 2021年7月(8)
- 2021年6月(5)
- 2021年5月(2)
- 2021年4月(3)
- 2021年3月(7)
- 2021年2月(2)
- 2021年1月(8)
- 2020年12月(7)
- 2020年11月(2)
- 2020年10月(6)
- 2020年9月(9)
- 2020年8月(10)
- 2020年7月(9)
- 2020年6月(18)
- 2020年5月(4)
- 2020年4月(25)
- 2020年3月(38)
- 2020年1月(21)
- 2019年12月(13)
- 2019年11月(29)
- 2019年10月(44)
- 2019年9月(17)
- 2019年8月(18)
- 2019年7月(25)
- 2019年6月(25)
- 2019年5月(17)
- 2019年4月(10)
- 2019年3月(36)
- 2019年2月(35)
- 2019年1月(28)
- 2018年12月(30)
- 2018年11月(22)
- 2018年10月(4)
- 2018年9月(7)
- 2018年8月(13)
- 2018年7月(13)
- 2018年6月(6)
- 2018年5月(5)
- 2018年4月(13)
- 2018年3月(5)
- 2018年2月(3)
- 2018年1月(8)
- 2017年12月(35)
- 2017年11月(17)
- 2017年10月(16)
- 2017年9月(17)
- 2017年8月(20)
- 2017年7月(34)
- 2017年6月(17)
- 2017年5月(15)
- 2017年4月(32)
- 2017年3月(8)
- 2017年2月(2)
- 2017年1月(5)
- 2016年12月(14)
- 2016年11月(26)
- 2016年10月(12)
- 2016年9月(25)
- 2016年8月(32)
- 2016年7月(14)
- 2016年6月(21)
- 2016年5月(17)
- 2016年4月(13)
- 2016年3月(8)
- 2016年2月(8)
- 2016年1月(18)
- 2015年12月(13)
- 2015年11月(15)
- 2015年10月(12)
- 2015年9月(18)
- 2015年8月(21)
- 2015年7月(35)
- 2015年6月(13)
- 2015年5月(9)
- 2015年4月(4)
- 2015年3月(5)
- 2015年2月(4)
- 2015年1月(13)
- 2014年12月(7)
- 2014年11月(5)
- 2014年10月(4)
- 2014年9月(8)
- 2014年8月(16)
- 2014年7月(26)
- 2014年6月(22)
- 2014年5月(28)
- 2014年4月(15)
友情链接
- Unity官网
- Unity圣典
- Unity在线手册
- Unity中文手册(圣典)
- Unity官方中文论坛
- Unity游戏蛮牛用户文档
- Unity下载存档
- Unity引擎源码下载
- Unity服务
- Unity Ads
- wiki.unity3d
- Visual Studio Code官网
- SenseAR开发文档
- MSDN
- C# 参考
- C# 编程指南
- .NET Framework类库
- .NET 文档
- .NET 开发
- WPF官方文档
- uLua
- xLua
- SharpZipLib
- Protobuf-net
- Protobuf.js
- OpenSSL
- OPEN CASCADE
- JSON
- MessagePack
- C在线工具
- 游戏蛮牛
- GreenVPN
- 聚合数据
- 热云
- 融云
- 腾讯云
- 腾讯开放平台
- 腾讯游戏服务
- 腾讯游戏开发者平台
- 腾讯课堂
- 微信开放平台
- 腾讯实时音视频
- 腾讯即时通信IM
- 微信公众平台技术文档
- 白鹭引擎官网
- 白鹭引擎开放平台
- 白鹭引擎开发文档
- FairyGUI编辑器
- PureMVC-TypeScript
- 讯飞开放平台
- 亲加通讯云
- Cygwin
- Mono开发者联盟
- Scut游戏服务器引擎
- KBEngine游戏服务器引擎
- Photon游戏服务器引擎
- 码云
- SharpSvn
- 腾讯bugly
- 4399原创平台
- 开源中国
- Firebase
- Firebase-Admob-Unity
- google-services-unity
- Firebase SDK for Unity
- Google-Firebase-SDK
- AppsFlyer SDK
- android-repository
- CQASO
- Facebook开发者平台
- gradle下载
- GradleBuildTool下载
- Android Developers
- Google中国开发者
- AndroidDevTools
- Android社区
- Android开发工具
- Google Play Games Services
- Google商店
- Google APIs for Android
- 金钱豹VPN
- TouchSense SDK
- MakeHuman
- Online RSA Key Converter
- Windows UWP应用
- Visual Studio For Unity
- Open CASCADE Technology
- 慕课网
- 阿里云服务器ECS
- 在线免费文字转语音系统
- AI Studio
- 网云穿
- 百度网盘开放平台
- 迅捷画图
- 菜鸟工具
- [CSDN] 程序员研修院
- 华为人脸识别
- 百度AR导航导览SDK
- 海康威视官网
- 海康开放平台
- 海康SDK下载
- git download
交流QQ群
-
Flash游戏设计: 86184192
Unity游戏设计: 171855449
游戏设计订阅号