C# dotnet WPF 使用 OpenXml 解析 Excel 文件

2023-10-28 10:30

本文主要是介绍C# dotnet WPF 使用 OpenXml 解析 Excel 文件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在 2013 微软开源了 OpenXml 解析库,在微软的 Excel 文档,使用的文档格式就是国际规范的 OpenXml 格式。这个格式有很多版本,详细请看百度。因为表格文稿使用的是 OpenXml 在 .NET 开发可以非常简单将 Excel 文档进行解析,大概只需要两句话

本文通过一个简单的 WPF 程序告诉大家如何解析,这个简单的 WPF 程序简单到仅有一个按钮,在点击按钮时自动解析 Excel 文档的内容

用 OpenXML 能做什么?其实可以做的东西很多,例如在 WPF 或 UWP 或 Xamarin 等里面使用 OpenXML 解析读取 Excel 文件内容,读取 PPT 和 Word 等文档的内容,只要符合 OpenXML 格式就能进行读取

通过 NuGet 安装 Openxml 库,这个库支持跨平台,因为只是解析数据

然后在按钮点击的代码里面添加下面代码解析

using (FileStream fs = new FileStream(fileName, FileMode.Open, FileAccess.Read, FileShare.ReadWrite))
{using (SpreadsheetDocument doc = SpreadsheetDocument.Open(fs, false)){}
}

大概这样就解析完成了,上面代码的 fileName 就是传入的文件,如下面代码

string fileName = @"f:\lindexi\FurlalloganarBerkojelfarwiwa.xlsx";

在 Excel 里面有多个标签,下面代码是获取第一个标签

WorkbookPart workbookPart = doc.WorkbookPart;
SharedStringTablePart sstpart = workbookPart.GetPartsOfType<SharedStringTablePart>().First();
SharedStringTable sst = sstpart.SharedStringTable;WorksheetPart worksheetPart = workbookPart.WorksheetParts.First();
Worksheet sheet = worksheetPart.Worksheet;

如果读取格子里面内容,可以使用下面代码

var cells = sheet.Descendants<Cell>();
var rows = sheet.Descendants<Row>();Debug.WriteLine("Row count = {0}", rows.LongCount());
Debug.WriteLine("Cell count = {0}", cells.LongCount());// One way: go through each cell in the sheet
foreach (Cell cell in cells)
{if ((cell.DataType != null) && (cell.DataType == CellValues.SharedString)){int ssid = int.Parse(cell.CellValue.Text);string str = sst.ChildElements[ssid].InnerText;Debug.WriteLine("Shared string {0}: {1}", ssid, str);}else if (cell.CellValue != null){Debug.WriteLine("Cell contents: {0}", cell.CellValue.Text);}
}// Or... via each row
foreach (Row row in rows)
{foreach (Cell c in row.Elements<Cell>()){if ((c.DataType != null) && (c.DataType == CellValues.SharedString)){int ssid = int.Parse(c.CellValue.Text);string str = sst.ChildElements[ssid].InnerText;Debug.WriteLine("Shared string {0}: {1}", ssid, str);}else if (c.CellValue != null){Debug.WriteLine("Cell contents: {0}", c.CellValue.Text);}}
}

如果想要了解解析的每个对象的内容,我推荐在对应的代码添加断点,如想要了解 row 的值等,可以如下图添加一个断点,然后通过局部变量窗口就可以看到每个变量的值

代码放在 github 欢迎小伙伴访问

如何添加断点请看 VisualStudio 断点调试详解

除了使用 OpenXML SDK 这个免费的库之外,还可以使用 EPPlus 这个收费或 LGPL 的库

更多请看 Office 使用 OpenXML SDK 解析文档博客目录

我搭建了自己的博客 https://blog.lindexi.com/ 欢迎大家访问,里面有很多新的博客。只有在我看到博客写成熟之后才会放在csdn或博客园,但是一旦发布了就不再更新

如果在博客看到有任何不懂的,欢迎交流,我搭建了 dotnet 职业技术学院 欢迎大家加入

如有不方便在博客评论的问题,可以加我 QQ 2844808902 交流

知识共享许可协议
本作品采用知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议进行许可。欢迎转载、使用、重新发布,但务必保留文章署名林德熙(包含链接:http://blog.csdn.net/lindexi_gd ),不得用于商业目的,基于本文修改后的作品务必以相同的许可发布。如有任何疑问,请与我联系。


http://www.taodudu.cc/news/show-8076195.html

相关文章:

  • 03.web静态页面学习,以百度为例
  • python有什么好玩的库_Python 社区里有趣且实用的库有哪些?
  • 2.wifi开发,SDK目录结构研究,SDK的API,如何生成可烧录代码,Freertos在esp8266使用,实验:wifi打印/点灯,实验:wifi入网/自建网,补充:查找已连接wifi密码
  • Vue基础学习以及Vue指令介绍
  • php 如何写入、读取word,excel文档
  • poi操作word文档,以07版本为参考,将word文档中图片替换为文本(替换文本也一样),读图片可选文字内容
  • Android如何通过代码方式打开微博 微信等应用.
  • 51CTO微博开通、使用须知
  • 测一测程序员的知识广度?
  • 程序员必考卷(文史综合卷)
  • 程序员的文史综合题你能做几题
  • 从鲁迅大撤退谈起中国文化
  • 1.3 运算符和表达式
  • day03——运算符与三码
  • 【Java基础】Java的运算符——21天学习计划打卡第四天
  • 【Java基础】运算符
  • day03-java基础-运算符
  • day03-Java运算符和表达式
  • 03-运算符
  • 【十二天学java】day03java基础语法
  • springBoot中常用接口的分析
  • 网易2016研发工程师编程题-----炮台攻击
  • 算法刷题
  • 赛码网练习——黑默丁格的炮台
  • 我们总在危难中发现珍贵与唾弃
  • 如此病毒营销,必将导致唾弃!
  • 少年碎碎念:《我要亮》
  • 苹果剔除中国供应链企业被市场唾弃,iPad的出货量暴跌三成
  • 你、我和世界
  • 我赢职场告诉你为什么凤姐会逆袭成励志姐?
  • 这篇关于C# dotnet WPF 使用 OpenXml 解析 Excel 文件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



    http://www.chinasem.cn/article/292586

    相关文章

    Java实战之利用POI生成Excel图表

    《Java实战之利用POI生成Excel图表》ApachePOI是Java生态中处理Office文档的核心工具,这篇文章主要为大家详细介绍了如何在Excel中创建折线图,柱状图,饼图等常见图表,需要的... 目录一、环境配置与依赖管理二、数据源准备与工作表构建三、图表生成核心步骤1. 折线图(Line Ch

    Python3脚本实现Excel与TXT的智能转换

    《Python3脚本实现Excel与TXT的智能转换》在数据处理的日常工作中,我们经常需要将Excel中的结构化数据转换为其他格式,本文将使用Python3实现Excel与TXT的智能转换,需要的可以... 目录场景应用:为什么需要这种转换技术解析:代码实现详解核心代码展示改进点说明实战演练:从Excel到

    如何使用CSS3实现波浪式图片墙

    《如何使用CSS3实现波浪式图片墙》:本文主要介绍了如何使用CSS3的transform属性和动画技巧实现波浪式图片墙,通过设置图片的垂直偏移量,并使用动画使其周期性地改变位置,可以创建出动态且具有波浪效果的图片墙,同时,还强调了响应式设计的重要性,以确保图片墙在不同设备上都能良好显示,详细内容请阅读本文,希望能对你有所帮助...

    Rust中的注释使用解读

    《Rust中的注释使用解读》本文介绍了Rust中的行注释、块注释和文档注释的使用方法,通过示例展示了如何在实际代码中应用这些注释,以提高代码的可读性和可维护性... 目录Rust 中的注释使用指南1. 行注释示例:行注释2. 块注释示例:块注释3. 文档注释示例:文档注释4. 综合示例总结Rust 中的注释

    C# string转unicode字符的实现

    《C#string转unicode字符的实现》本文主要介绍了C#string转unicode字符的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随... 目录1. 获取字符串中每个字符的 Unicode 值示例代码:输出:2. 将 Unicode 值格式化

    Linux使用cut进行文本提取的操作方法

    《Linux使用cut进行文本提取的操作方法》Linux中的cut命令是一个命令行实用程序,用于从文件或标准输入中提取文本行的部分,本文给大家介绍了Linux使用cut进行文本提取的操作方法,文中有详... 目录简介基础语法常用选项范围选择示例用法-f:字段选择-d:分隔符-c:字符选择-b:字节选择--c

    使用Go语言开发一个命令行文件管理工具

    《使用Go语言开发一个命令行文件管理工具》这篇文章主要为大家详细介绍了如何使用Go语言开发一款命令行文件管理工具,支持批量重命名,删除,创建,移动文件,需要的小伙伴可以了解下... 目录一、工具功能一览二、核心代码解析1. 主程序结构2. 批量重命名3. 批量删除4. 创建文件/目录5. 批量移动三、如何安

    springboot的调度服务与异步服务使用详解

    《springboot的调度服务与异步服务使用详解》本文主要介绍了Java的ScheduledExecutorService接口和SpringBoot中如何使用调度线程池,包括核心参数、创建方式、自定... 目录1.调度服务1.1.JDK之ScheduledExecutorService1.2.spring

    Java使用Tesseract-OCR实战教程

    《Java使用Tesseract-OCR实战教程》本文介绍了如何在Java中使用Tesseract-OCR进行文本提取,包括Tesseract-OCR的安装、中文训练库的配置、依赖库的引入以及具体的代... 目录Java使用Tesseract-OCRTesseract-OCR安装配置中文训练库引入依赖代码实

    Python自动化办公之合并多个Excel

    《Python自动化办公之合并多个Excel》在日常的办公自动化工作中,尤其是处理大量数据时,合并多个Excel表格是一个常见且繁琐的任务,下面小编就来为大家介绍一下如何使用Python轻松实现合... 目录为什么选择 python 自动化目标使用 Python 合并多个 Excel 文件安装所需库示例代码