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

    相关文章

    C#如何去掉文件夹或文件名非法字符

    《C#如何去掉文件夹或文件名非法字符》:本文主要介绍C#如何去掉文件夹或文件名非法字符的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C#去掉文件夹或文件名非法字符net类库提供了非法字符的数组这里还有个小窍门总结C#去掉文件夹或文件名非法字符实现有输入字

    C#之List集合去重复对象的实现方法

    《C#之List集合去重复对象的实现方法》:本文主要介绍C#之List集合去重复对象的实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C# List集合去重复对象方法1、测试数据2、测试数据3、知识点补充总结C# List集合去重复对象方法1、测试数据

    C#实现将Office文档(Word/Excel/PDF/PPT)转为Markdown格式

    《C#实现将Office文档(Word/Excel/PDF/PPT)转为Markdown格式》Markdown凭借简洁的语法、优良的可读性,以及对版本控制系统的高度兼容性,逐渐成为最受欢迎的文档格式... 目录为什么要将文档转换为 Markdown 格式使用工具将 Word 文档转换为 Markdown(.

    CnPlugin是PL/SQL Developer工具插件使用教程

    《CnPlugin是PL/SQLDeveloper工具插件使用教程》:本文主要介绍CnPlugin是PL/SQLDeveloper工具插件使用教程,具有很好的参考价值,希望对大家有所帮助,如有错... 目录PL/SQL Developer工具插件使用安装拷贝文件配置总结PL/SQL Developer工具插

    SpringBoot3中使用虚拟线程的完整步骤

    《SpringBoot3中使用虚拟线程的完整步骤》在SpringBoot3中使用Java21+的虚拟线程(VirtualThreads)可以显著提升I/O密集型应用的并发能力,这篇文章为大家介绍了详细... 目录1. 环境准备2. 配置虚拟线程方式一:全局启用虚拟线程(Tomcat/Jetty)方式二:异步

    使用Python实现base64字符串与图片互转的详细步骤

    《使用Python实现base64字符串与图片互转的详细步骤》要将一个Base64编码的字符串转换为图片文件并保存下来,可以使用Python的base64模块来实现,这一过程包括解码Base64字符串... 目录1. 图片编码为 Base64 字符串2. Base64 字符串解码为图片文件3. 示例使用注意

    使用Python实现获取屏幕像素颜色值

    《使用Python实现获取屏幕像素颜色值》这篇文章主要为大家详细介绍了如何使用Python实现获取屏幕像素颜色值,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 一、一个小工具,按住F10键,颜色值会跟着显示。完整代码import tkinter as tkimport pyau

    Java调用C#动态库的三种方法详解

    《Java调用C#动态库的三种方法详解》在这个多语言编程的时代,Java和C#就像两位才华横溢的舞者,各自在不同的舞台上展现着独特的魅力,然而,当它们携手合作时,又会碰撞出怎样绚丽的火花呢?今天,我们... 目录方法1:C++/CLI搭建桥梁——Java ↔ C# 的“翻译官”步骤1:创建C#类库(.NET

    Linux使用scp进行远程目录文件复制的详细步骤和示例

    《Linux使用scp进行远程目录文件复制的详细步骤和示例》在Linux系统中,scp(安全复制协议)是一个使用SSH(安全外壳协议)进行文件和目录安全传输的命令,它允许在远程主机之间复制文件和目录,... 目录1. 什么是scp?2. 语法3. 示例示例 1: 复制本地目录到远程主机示例 2: 复制远程主

    Java Lambda表达式的使用详解

    《JavaLambda表达式的使用详解》:本文主要介绍JavaLambda表达式的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、前言二、Lambda表达式概述1. 什么是Lambda表达式?三、Lambda表达式的语法规则1. 无参数的Lambda表