当前位置: 首页 > 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.lqws.cn/news/468271.html

相关文章:

  • 细节/数学/滑动窗口
  • Nginx+tomcat集群
  • 多头注意力机制中全连接函数
  • 成长笔记——多串口发送与接收
  • 面试题-函数类型的重载是啥意思
  • Qt + C++ 入门2(界面的知识点)
  • 吐槽之前后端合作开发
  • FastAPI框架的10个重要知识点总结
  • Typora文档另存与图片迁移的一种思路
  • VR飞夺泸定桥沉浸式历史再现​
  • [C++] STL数据结构小结
  • Linux - 安装 git(sudo apt-get)
  • WPF Style样式 全局样式资源字典
  • Qt/C++应用:防御性编程完全指南
  • leetcode332.重新安排行程:优先队列与DFS实现欧拉路径的行程规划
  • 【智能体】n8n聊天获取链接后爬虫知乎
  • 108. 将有序数组转换为二叉搜索树
  • Vue.js核心概念与实践指南:从实例绑定到数据代理
  • opencv try-catch
  • BGP路由反射器(RR)实验详解,结尾有详细脚本
  • 在 `setup` 函数中使用 Vuex
  • 自定义 Spring starter 的原理详解
  • 港科ISM选课攻略整理
  • CVE-2024-6387漏洞、CVE-2025-26465漏洞、CVE-2025-26466漏洞 一口气全解决
  • 【nature review】原子尺度上光与物质的相互作用
  • Rabbitmq的五种消息类型介绍,以及集成springboot的使用
  • 小程序右上角○关闭事件
  • c++中 Lambda表达式
  • Ubuntu崩溃修复大赛的技术文章大纲
  • ssssssssss