当前位置: 首页 > 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

相关文章:

  • 【舞蹈】编排:如何对齐拍子并让小节倍数随BPM递减
  • 经典控制理论:线性化笔记
  • PowerBI HtmlContent生成表格
  • 磁性传感器在电机控制闭环系统中的反馈作用
  • 【JAVA】数组的使用
  • 数据分析核心指标体系:从求和、计数到比较的全维度计算方法
  • 基于ARM ubuntu如何进行交叉编译
  • 针对机器人自修复材料的具体推荐及特性分析
  • 操作系统进程与线程核心知识全览
  • 如何定时发布WordPress文章(多种方法)
  • 日常开发常用工具和技巧以及遇到的问题
  • 闲庭信步使用SV进行图像处理系列教程介绍
  • 跟着AI学习C# Day29
  • Rabbitmq集成springboot,手动确认消息basicAck、basicNack、basicReject的使用
  • 应对进行性核上性麻痹,科学护理指南
  • 本地回环地址在广播风暴与环路排查中的实战指南
  • 简单通过SenseVoice给自己配置一个语音转文字服务
  • Django中为api自定义一些装饰器:如参数校验等
  • GeoJSON 数据简介
  • Android 终端模拟器 termux app
  • 移除wordpress4版本号/seo推广编辑
  • 电子政务门户网站建设教训/中国世界排名
  • 沈阳做网站比较好的公司/seo的关键词无需
  • 如何选择镇江网站建设/怎么能在百度上做推广
  • 机械厂做网站/我是做推广的怎么找客户
  • 石家庄官网制作/网站排名优化客服