当前位置: 首页 > news >正文

C#测试调用ClosedXML根据批注设置excel单元格内容

  如果需要向Excel文件的特定单元格写内容,但单元格位置又不固定,可以考虑设置单元格的批注,通过查找特定批注找到单元格,向单元格写入内容后删除批注。本文测试调用ClosedXML查找带特定批注的excel单元格并设置内容。ClosedXML属于.NET开源库,用于读写、操作2007及以上版本的Excel文件(.xlsx、.xlsm),详细介绍及源码见参考文献1.
  VS2022新建Winform项目,在Nuget包管理器中搜索并安装ClosedXML包,如下图所示。

在这里插入图片描述
  新建测试excel文件,通过审阅工具栏在单元格中新建批注,如下图所示。
在这里插入图片描述
  调用ClosedXML模块的XLWorkbook类打开excel文件,获取第一个工作簿worksheet 对象,worksheet的CellsUsed函数能够返回被使用的单元格,支持按枚举值或者筛选函数返回特定形式的单元格。测试过程中才想到其实不用纠结于带注释的单元格,直接设置单元格内容,然后查找带指定内容的单元格也可以,不过测都测了,就这样吧。使用示例代码如下所示:

var workbook = new XLWorkbook(txtFilePath.Text);
var worksheet = workbook.Worksheets.First();// 最开始调用下面的注释语句获取仅包含注释的单元格,但是返回的是所有使用的单元格
// 不清楚是理解的不对还是调用方式不对
// IXLCells cells = worksheet.CellsUsed(XLCellsUsedOptions.Comments);
IXLCells cells = worksheet.CellsUsed(r=>r.HasComment);foreach(IXLCell cell in cells)
{//if(!cell.HasComment)//{//    continue;//}if(cell.GetComment().Text==txtPz.Text){cell.Value=txtContent.Text;cell.GetComment().Delete(); }
}workbook.Save();//不想会写到源文件可以调用SaveAs函数另存为

  最后是测试程序截图,如下所示:
在这里插入图片描述
在这里插入图片描述
参考文献:
[1]https://github.com/ClosedXML/ClosedXML

http://www.lryc.cn/news/573270.html

相关文章:

  • 企业公用电脑登录安全管控的终极方案:ASP操作系统安全登录管控方案
  • 亚马逊认证考试系列 - 第一部份:基础服务 - AWS SAA C03
  • 客户端面经
  • 决策树:化繁为简的智能决策利器
  • 【Kubernetes】从零搭建K8s集群:虚拟机环境配置全指南(DNS/网络/防火墙/SELinux全解析一站式配置图文教程)
  • 题解:P11501 [ROIR 2019] 探险队(Day 2)
  • FPGA四十年创新:因仿真加速而生,AI加速而盛!
  • 【RTP】基于mediasoup的RtpPacket的H.264打包、解包和demo 2:含扩展
  • 11.RSTP快速生成树协议深度剖析:结合华为eNSP模拟器的完整实验方案
  • 为什么要BRE
  • LLM-201: OpenHands与LLM交互链路分析
  • 【基础算法】二分(二分查找 + 二分答案)
  • 华为云Flexus+DeepSeek征文|体验华为云ModelArts快速搭建Dify-LLM应用开发平台并创建b站视频总结大模型
  • Vue3 + TypeScript 中 let data: any[] = [] 与 let data = [] 的区别
  • C++ 内存分配器的作用
  • AI+预测3D新模型百十个定位预测+胆码预测+去和尾2025年6月21日第115弹
  • 【舞蹈】编排:如何对齐拍子并让小节倍数随BPM递减
  • 56-Oracle SQL Tuning Advisor(STA)
  • hot100——第六周
  • MagnTek MT6816-ACD 一款基于各向异性磁阻(AMR)技术的磁性角度传感器 IC
  • wordpress外贸独立站常用留言表单插件 contact form 7
  • 探索 Oracle Database 23ai 中的 SQL 功能
  • 小程序右上角○关闭事件
  • 基于深度学习的侧信道分析(DLSCA)Python实现(带测试)
  • RNN工作原理和架构
  • `teleport` 传送 API 的使用:在 Vue 3 中的最佳实践
  • Thrift 服务端的完整示例
  • 【设计模式】4.代理模式
  • 分组交换比报文交换的传输时延更低
  • PHP语法基础篇(五):流程控制