全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

C# Open XML SDK怎么创建和修改Excel文件

Open XML SDK 通过操作 .xlsx 的 ZIP 结构和 XML 实现无 Excel 依赖的轻量高效处理:创建需构建 WorkbookPart 等部件并填充 SheetData;修改需定位 XML 节点更新 CellValue/DataType;数值、日期、公式、样式须严格按规范设置;简单场景推荐 EPPlus/NPOI/ClosedXML。

用 C# 的 Open XML SDK 创建和修改 Excel 文件,核心是操作 .xlsx 的底层 ZIP 结构和 XML 内容,不依赖 Excel 应用程序,轻量、高效、适合服务端批量处理。

创建新 Excel 文件(.xlsx)

新建工作簿本质是生成符合 Office Open XML 标准的文件结构:包含 WorkbookPart、WorksheetPart、SharedStringTablePart 等部件。关键步骤如下:

  • SpreadsheetDocument.Create() 创建空文档,并指定 SpreadsheetDocumentType.Workbook
  • 添加 WorkbookPart,再在其中添加 WorksheetPart(每个 Sheet 对应一个)
  • 手动或通过 SharedStringTablePart 管理文本(避免重复存储相同字符串)
  • SheetData 中逐行添加 RowCell,注意设置 Cell.CellValueCell.DataType(如 CellValues.StringCellValues.Number
  • 最后调用 workbook.Save()document.Close()

小技巧:首次创建时建议先用 Excel 手动保存一个极简模板(1 行 1 列),再用 Open XML SDK Productivity Tool 查看其内部结构,对照编码更不容易出错。

修改已有 Excel 文件

打开现有文件用 SpreadsheetDocument.Open(path, true)true 表示可写)。重点不是“编辑单元格”,而是定位并更新对应 XML 节点:

  • 通过 WorkbookPart.Workbook.Sheets 找到目标 Sheet,再用 WorksheetPart 获取其 Worksheet
  • 遍历 Worksheet.GetFirstChild().Elements() 定位行,再找 Cell(可用 cell.CellReference.Value == "A1" 匹配)
  • 修改 cell.CellValue.Text,若类型变化(如从文本改数字),需同步设 cell.DataType 并处理数值格式
  • 如果新增内容超出原 SheetData 范围,需手动追加 RowCell,注意维护行号和列引用(如 "B5")

注意:直接改 CellValue 不会自动刷新公式结果或样式——Open XML 只管存储,不计算。

写入数值、日期、公式和样式的要点

Open XML 对数据类型和格式要求严格,容易踩坑:

  • 数值:设 cell.DataType = null(默认为数字),cell.CellValue = new CellValue("123.45")
  • 日期:Excel 内部存为浮点数(从 1900-01-01 起的天数),用 DateTime.ToOADate() 转换,且必须设 cell.StyleIndex 指向带日期格式的 CellFormat
  • 公式:设 cell.CellFormula = new CellFormula("SUM(A1:A10)"),同时设 cell.DataType = CellValues.Formula;注意公式值(CellValue)应为上次计算结果(否则 Excel 打开会显示 #VALUE!)
  • 样式:需提前在 WorkbookPartWorkbookStylesPart 中定义 FontsFillsBordersCellFormats,再通过 cell.StyleIndex 引用索引

推荐替代方案(简单场景优先考虑)

如果只是读写数据、不涉及复杂样式或公式,Open XML SDK 学习成本高、代码冗长。可考虑:

  • EPPlus(.NET 5+ 推荐):API 友好,支持公式、图表、样式,开源免费(MIT 协议),用法接近 Excel Interop 但无 COM 依赖
  • NPOI:Java POI 的 .NET 移植,兼容老版 .xls,社区活跃,文档较全
  • ClosedXML:封装 Open XML,语法简洁(如 ws.Cell("A1").Value = "Hello"),适合快速开发

Open XML SDK 最适合需要精细控制文件结构、做深度定制(如加密、自定义 XML 部件)、或构建底层工具链的场景。

基本上就这些。用 Open XML SDK 处理 Excel,逻辑清晰但细节多,关键是理解“文件即 ZIP + XML”的本质,动手调试几次结构就顺了。


# excel  # java  # 编码  # 工具  # office  # c#  # .net  # red 


相关文章: 专业的网站制作设计是什么,如何制作一个企业网站,建设网站的基本步骤有哪些?  建站主机选购指南:核心配置与性价比推荐解析  如何在万网自助建站平台快速创建网站?  建站主机核心功能解析:服务器选择与网站搭建流程指南  广德云建站网站建设方案与建站流程优化指南  盐城做公司网站,江苏电子版退休证办理流程?  在线ppt制作网站有哪些软件,如何把网页的内容做成ppt?  建站主机服务器选购指南:轻量应用与VPS配置解析  网站制作网站,深圳做网站哪家比较好?  威客平台建站流程解析:高效搭建教程与设计优化方案  如何通过PHP快速构建高效问答网站功能?  贸易公司网站制作流程,出口贸易网站设计怎么做?  JS中使用new Date(str)创建时间对象不兼容firefox和ie的解决方法(两种)  如何快速搭建自助建站会员专属系统?  网页设计网站制作软件,microsoft office哪个可以创建网页?  建站主机选购指南与交易推荐:核心配置解析  江苏网站制作公司有哪些,江苏书法考级官方网站?  如何零基础开发自助建站系统?完整教程解析  如何用PHP快速搭建高效网站?分步指南  中山网站制作网页,中山新生登记系统登记流程?  子杰智能建站系统|零代码开发与AI生成SEO优化指南  如何快速搭建高效简练网站?  网站制作公司,橙子建站是合法的吗?  浅谈Javascript中的Label语句  如何在服务器上三步完成建站并提升流量?  建站之星客服服务时间及联系方式如何?  如何用PHP工具快速搭建高效网站?  如何快速重置建站主机并恢复默认配置?  Python lxml的etree和ElementTree有什么区别  建站ABC备案流程中有哪些关键注意事项?  建站之星24小时客服电话如何获取?  如何用手机制作网站和网页,手机移动端的网站能制作成中英双语的吗?  定制建站哪家更专业可靠?推荐榜单揭晓  nginx修改上传文件大小限制的方法  家庭建站与云服务器建站,如何选择更优?  Swift中循环语句中的转移语句 break 和 continue  建站之星图片链接生成指南:自助建站与智能设计教程  如何用wdcp快速搭建高效网站?  西安制作网站公司有哪些,西安货运司机用的最多的app或者网站是什么?  免费制作海报的网站,哪位做平面的朋友告诉我用什么软件做海报比较好?ps还是cd还是ai这几个软件我都会些我是做网页的?  建站之星官网登录失败?如何快速解决?  深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?  建站主机如何选?高性价比方案全解析  如何选择CMS系统实现快速建站与SEO优化?  手机网站制作与建设方案,手机网站如何建设?  制作销售网站教学视频,销售网站有哪些?  寿县云建站:智能SEO优化与多行业模板快速上线指南  公司网站制作价格怎么算,公司办个官网需要多少钱?  宝塔新建站点为何无法访问?如何排查?  北京网站制作费用多少,建立一个公司网站的费用.有哪些部分,分别要多少钱? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。