借助Aapose.Cells 使用 C# 在 Excel 中读取、添加和编辑线程注释
Excel 中的线程注释是协作工作的重要功能。它允许多个用户在共享文档中添加、编辑和查看对话线程。在某些情况下,我们可能需要以编程方式管理这些线程注释。在这篇博文中,我们将学习如何使用 C# 在 Excel 中读取、添加和编辑线程注释。
Aspose.Cells 是Excel电子表格编程API,可加快电子表格的管理和处理任务,支持构建能够生成,修改,转换,呈现和打印电子表格的跨平台应用程序。同时不依赖于Microsoft Excel或任何Microsoft Office Interop组件,Aspose API 支持旗下产品覆盖文档、图表、PDF、条码、OCR、CAD、HTML、电子邮件等各个文档管理领域,为全球.NET 、Java、C ++等10余种平台开发人员提供丰富的开发选择。
用于管理线程评论的 C# Excel API
为了处理 Excel 工作表中的线程注释,我们将使用Aspose.Cells for .NET API。它是一个功能强大的电子表格编程 API,使开发人员能够在 .NET 应用程序中创建、操作和转换 Excel 文件。通过利用 Aspose.Cells for .NET,我们可以轻松地在 Excel 工作表中添加、读取、编辑或删除线程注释。
要使用 API,请下载 DLL或使用以下命令从NuGet安装它:
PM> Install-Package Aspose.Cells
使用 C# 在 Excel 中添加线程注释
- 创建Workbook类的实例。
- 通过索引访问特定工作表。
- 使用Add()方法将作者添加到ThreadedCommentAuthors集合。
- 通过索引获取新创建的作者的ThreadedCommentAuthor类对象。
- 使用AddThreadedComment()方法添加线程注释。该方法以单元格名称、注释文本和 ThreadedCommentAuthor 对象作为参数。
- 使用Workbook.Save(string)方法保存 Excel 文件。
以下代码示例显示如何使用 C# 向 Excel 工作表添加线程注释。
// This code example demonstrates how to add threaded comments in an Excel worksheet // Create an instance of the Workbook class Workbook workbook = new Workbook();// Access the first worksheet Worksheet worksheet = workbook.Worksheets[0];// Add an Author var authorIndex = workbook.Worksheets.ThreadedCommentAuthors.Add("Aspose Test", "", ""); var author = workbook.Worksheets.ThreadedCommentAuthors[authorIndex];// Add Threaded Comment worksheet.Comments.AddThreadedComment("A1", "Test Threaded Comment", author);// Save the output file workbook.Save("AddThreadedComments_out.xlsx");
阅读 Excel 中特定单元格的线程注释
要从 Excel 工作表中的指定单元格读取线程注释,请按照以下步骤操作:
- 使用Workbook类加载现有的 Excel 文件。
- 通过索引访问工作表。
- 使用GetThreadedComments()方法获取特定单元格的线程注释。该方法以单元格名称作为参数。
- 循环浏览所有主题评论并阅读详细信息。
以下代码示例显示如何使用 C# 从 Excel 工作表中读取指定列的线程注释。
// This code example demonstrates how to read threaded comments for a specified cell in an Excel worksheet // Load an existing Excel file Workbook workbook = new Workbook("AddThreadedComments_out.xlsx");// Access the first worksheet Worksheet worksheet = workbook.Worksheets[0];// Get Threaded Comments for a specific cell var threadedComments = worksheet.Comments.GetThreadedComments("A1");// Read the threaded comments foreach (var comment in threadedComments) { Console.WriteLine("Author Name: " + comment.Author.Name); Console.WriteLine("Threaded comment Notes:" + comment.Notes); }Author Name: author@domain.com Threaded comment Notes:Test Threaded Comment
使用 C# 读取 Excel 中的所有主题注释
类似地,我们可以按照以下步骤读取 Excel 工作表中所有可用的主题评论:
- 使用Workbook类加载现有的 Excel 文件。
- 循环浏览所有评论并逐一阅读主题评论。
以下代码示例显示如何使用 C# 从 Excel 工作表读取所有线程注释。
// This code example demonstrates how to read threaded comments for a specified cell in an Excel worksheet // Load an existing Excel file Workbook workbook = new Workbook("AddThreadedComments_out.xlsx");// Access the first worksheet Worksheet worksheet = workbook.Worksheets[0];// Get all the comments var comments = worksheet.Comments;// Read all the threaded comments foreach (var comment in comments) { // Process threaded comments foreach (var threadedComment in comment.ThreadedComments) { Console.WriteLine("Author Name: " + threadedComment.Author.Name); Console.WriteLine("Threaded comment author User Id: " + threadedComment.Author.UserId); Console.WriteLine("Threaded comment author ProviderId:" + threadedComment.Author.ProviderId); Console.WriteLine("Threaded comment Notes:" + threadedComment.Notes); } }
使用 C# 在 Excel 中编辑线程注释
请按照以下步骤更新 Excel 中的任何主题评论:
- 使用Workbook类加载现有的 Excel 文件。
- 通过索引访问工作表。
- 使用GetThreadedComments()方法获取特定单元格的线程注释。该方法以单元格名称作为参数。
- 更新评论的注释属性。
- 使用Workbook.Save(string)方法保存 Excel 文件。
以下代码示例展示如何使用 C# 编辑 Excel 工作表中的线程注释
// This code example demonstrates how to edit threaded comments in an Excel worksheet // Load an existing Excel file Workbook workbook = new Workbook("AddThreadedComments_out.xlsx");// Access the first worksheet Worksheet worksheet = workbook.Worksheets[0];// Get Threaded Comments for a specific cell var threadedComments = worksheet.Comments.GetThreadedComments("A1"); var comment = threadedComments[0];// Update the comment note comment.Notes = "Updated Comment";// Save the output file workbook.Save("EditThreadedComments.xlsx");
使用 C# 删除 Excel 中的主题评论
我们还可以按照以下步骤删除Excel工作表中特定单元格的线程注释:
- 使用Workbook类加载现有的 Excel 文件。
- 通过索引访问工作表。
- 使用RemoveAt()方法从评论集合中删除评论。该方法以单元格名称作为参数。
- 使用Save(string)方法保存Excel文件。
以下代码示例显示如何使用 C# 删除 Excel 工作表中的线程注释。
// This code example demonstrates how to delete threaded comments in an Excel worksheet // Load an existing Excel file Workbook workbook = new Workbook("AddThreadedComments_out.xlsx");// Get all the comments var comments = workbook.Worksheets[0].Comments;// Remove Comments comments.RemoveAt("A1");// Save the output file workbook.Save("DeleteThreadedComments.xlsx");
结论
在本文中,我们学习了如何使用 C# 读取、添加、编辑和删除 Excel 工作表中的线程注释。通过利用 Aspose.Cell for .NET,您可以轻松地在 C# 应用程序中操作 Excel 工作表。
相关文章:
借助Aapose.Cells 使用 C# 在 Excel 中读取、添加和编辑线程注释
Excel 中的线程注释是协作工作的重要功能。它允许多个用户在共享文档中添加、编辑和查看对话线程。在某些情况下,我们可能需要以编程方式管理这些线程注释。在这篇博文中,我们将学习如何使用 C# 在 Excel 中读取、添加和编辑线程注释。 Aspose.Cells 是…...

关于c++ grpc 和 c# grpc 通信的问题 以及 grpc 认证问题
一、c 和 c# 通信 c# 端服务器 如果域名 输入的是 https ,则 c 端需要匹配使用,也就是c 端需要进行安全认证。如果是http 则c 端不需要认证(基于c#的grpc 未 通信成功) 参考如下网址可以写一个简单的 .net grpc服务器 (…...

C++进阶(14)类型转换、IO流
文章目录 一、类型转换C语言隐式类型转换强制类型转换 C类型转换的情况类型转换的函数(4个) 二、IO流1、缓冲区2、提高输入输出效率3、文件操作文件权限写操作 --- ofstream文本方式写入二进制方式写入 读操作 --- ifstream文本方式读取二进制方式读取 其…...

配置oss cdn加速静态资源访问 阿里云
效果对比 配置cdn下载速度对比 步骤 1: 登录阿里云控制台控制台主页,找到并点击“对象存储 OSS” 创建存储空间(Bucket) 设置权限 步骤 2: 获取外网访问地址 步骤 3 在 CDN 中使用该地址 复制该外网访问地址 打开全站加速 DCDN/域名管理 添…...

实现 前端框架 SPA 路由功能:Hash 模式与 History 模式的手动实现
前言 在前端框架(如 Vue.js、React 等)中,路由管理通常会配置一个 router 对象来定义 URL 路径与组件的映射关系。 路径(path): 这是浏览器 URL 的一部分,比如 /home 或 /about。组件(compone…...

去中心化的新时代:Web3技术的全球影响
随着技术的不断演进,Web3正引领互联网的去中心化新时代。相较于传统的Web1和Web2,Web3通过去中心化、区块链和智能合约等技术,正在重塑网络的运作方式。这一变革不仅提升了网络的安全性和透明度,也对全球经济、社会和文化产生了深…...

初始redis:List
列表 List 相当于数组或者顺序表。 对于List来说,两侧都可以插入和删除,时间复杂度是O(1)。 有很多的操作,比如 llen 可以获取List的长度,lrem 可以删除元素 ,lrange可以去一个字符串 , lindex可以根据下标…...

Java | Leetcode Java题解之第355题设计推特
题目: 题解: class Twitter {private class Node {// 哈希表存储关注人的 IdSet<Integer> followee;// 用链表存储 tweetIdLinkedList<Integer> tweet;Node() {followee new HashSet<Integer>();tweet new LinkedList<Integer&g…...

MVC与三层架构分层
1. 应用分层 应用分层类似公司的组织架构。我们进行项目开发时,最开始功能简单,前后端放在一起开发,但随着项目功能的复杂,项目会被前端和后端不同的团队接手,甚至更细粒度的团队。甚至后端开发也会根据功能再进行细分…...
Go语言基础--switch
在Go语言中,switch语句是一种非常强大的控制流结构,它允许一个变量的值与多个case进行比较,并根据匹配的结果执行不同的代码块。与C、C或Java中的switch不同,Go语言的switch更灵活,支持没有显式条件的switch࿰…...

【数字ic自整资料】AXI握手协议及outstanding
参考资料: ic基础|时序篇:握手协议valid和ready的时序优化_valid和ready握手信号-CSDN博客 https://zhuanlan.zhihu.com/p/365573848 1、AXI握手协议 当我们遇到时序违例时,通常采用的方式为插入寄存器(打拍)或者是…...
C++ //练习 18.13 什么时候应该使用未命名的命名空间?
C Primer(第5版) 练习 18.13 练习 18.13 什么时候应该使用未命名的命名空间? 环境:Linux Ubuntu(云服务器) 工具:vim 解释 当需要将实体限定在特定文件中,并且不会作用于不同文件…...
yum小bug
这个错误是在克隆的机子上安装mysql时,查看有无mysql发现的 [rootwebserve-2 backup] # yum list installed | grep mysql Repository cr is listed more than once in the configuration Repository fasttrack is listed more than once in the configuration 这…...

GDB的基本使用
我有话说 因为时间和精力原因,本文写的虎头蛇尾了,除了启动调试与程序执行以外只有少量截图演示,只是简单的说明。如果有需要可以联系我,我有时间的话会把演示补上,谢谢理解。 启动调试与程序执行 启动调试并传递参数…...

如何利用AI创作高质量的文章
讯飞星火 利用AI创作高质量的文章需要遵循以下步骤: 确定主题和目标受众:在开始写作之前,明确文章的主题和目标受众。这将帮助你确定文章的风格、结构和内容。 收集资料和信息:在撰写文章之前,进行充分的研究&#x…...

开源的量化交易领域平台vn.py(VeighNa)
一:vn.py(VeighNa)下的工具以及社区版和Elite版的区别 vn.py是一款广泛应用于量化交易领域的开源软件,它主要有以下用途和功能: 1. 交易系统开发框架:vn.py提供了一个完整的交易系统开发框架,可…...
选择搜索引擎进行搜索
<!DOCTYPE html> <html> <head><meta charset"utf-8"><title>选择搜索引擎进行搜索</title><script>function searchSelectedEngine() {var keyword document.getElementById(keyword).value;var engine document.getEl…...
安卓framework修改density
安卓平台,不同屏幕分辨率需要修改density值,以适配UI显示,比如字体大小等. 命令行下进入安卓SDK源码的device/目录 再根据不同芯片厂进入不同目录, 比如展锐就是 cd device/sprd, 高通是device/qcom/搜索关键字"ro.sf.lcd_density", grep -nr “ro.sf.lcd_density”…...

我们如何将数据输入到神经网络中?
前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。 下面我拿识别美女的例子来给大家介绍如何将美女的图片数据输入到神经网络中。 此例中,待输入的数据是一张图像。为了存储图像…...
基于python模板的药品名称识别系统设计与实现
博主介绍: 大家好,本人精通Java、Python、C#、C、C编程语言,同时也熟练掌握微信小程序、Php和Android等技术,能够为大家提供全方位的技术支持和交流。 我有丰富的成品Java、Python、C#毕设项目经验,能够为学生提供各类…...
多场景 OkHttpClient 管理器 - Android 网络通信解决方案
下面是一个完整的 Android 实现,展示如何创建和管理多个 OkHttpClient 实例,分别用于长连接、普通 HTTP 请求和文件下载场景。 <?xml version"1.0" encoding"utf-8"?> <LinearLayout xmlns:android"http://schemas…...
STM32+rt-thread判断是否联网
一、根据NETDEV_FLAG_INTERNET_UP位判断 static bool is_conncected(void) {struct netdev *dev RT_NULL;dev netdev_get_first_by_flags(NETDEV_FLAG_INTERNET_UP);if (dev RT_NULL){printf("wait netdev internet up...");return false;}else{printf("loc…...

全球首个30米分辨率湿地数据集(2000—2022)
数据简介 今天我们分享的数据是全球30米分辨率湿地数据集,包含8种湿地亚类,该数据以0.5X0.5的瓦片存储,我们整理了所有属于中国的瓦片名称与其对应省份,方便大家研究使用。 该数据集作为全球首个30米分辨率、覆盖2000–2022年时间…...
【Web 进阶篇】优雅的接口设计:统一响应、全局异常处理与参数校验
系列回顾: 在上一篇中,我们成功地为应用集成了数据库,并使用 Spring Data JPA 实现了基本的 CRUD API。我们的应用现在能“记忆”数据了!但是,如果你仔细审视那些 API,会发现它们还很“粗糙”:有…...

多种风格导航菜单 HTML 实现(附源码)
下面我将为您展示 6 种不同风格的导航菜单实现,每种都包含完整 HTML、CSS 和 JavaScript 代码。 1. 简约水平导航栏 <!DOCTYPE html> <html lang"zh-CN"> <head><meta charset"UTF-8"><meta name"viewport&qu…...
Xen Server服务器释放磁盘空间
disk.sh #!/bin/bashcd /run/sr-mount/e54f0646-ae11-0457-b64f-eba4673b824c # 全部虚拟机物理磁盘文件存储 a$(ls -l | awk {print $NF} | cut -d. -f1) # 使用中的虚拟机物理磁盘文件 b$(xe vm-disk-list --multiple | grep uuid | awk {print $NF})printf "%s\n"…...
【SSH疑难排查】轻松解决新版OpenSSH连接旧服务器的“no matching...“系列算法协商失败问题
【SSH疑难排查】轻松解决新版OpenSSH连接旧服务器的"no matching..."系列算法协商失败问题 摘要: 近期,在使用较新版本的OpenSSH客户端连接老旧SSH服务器时,会遇到 "no matching key exchange method found", "n…...

Git 3天2K星标:Datawhale 的 Happy-LLM 项目介绍(附教程)
引言 在人工智能飞速发展的今天,大语言模型(Large Language Models, LLMs)已成为技术领域的焦点。从智能写作到代码生成,LLM 的应用场景不断扩展,深刻改变了我们的工作和生活方式。然而,理解这些模型的内部…...

解读《网络安全法》最新修订,把握网络安全新趋势
《网络安全法》自2017年施行以来,在维护网络空间安全方面发挥了重要作用。但随着网络环境的日益复杂,网络攻击、数据泄露等事件频发,现行法律已难以完全适应新的风险挑战。 2025年3月28日,国家网信办会同相关部门起草了《网络安全…...
Git常用命令完全指南:从入门到精通
Git常用命令完全指南:从入门到精通 一、基础配置命令 1. 用户信息配置 # 设置全局用户名 git config --global user.name "你的名字"# 设置全局邮箱 git config --global user.email "你的邮箱example.com"# 查看所有配置 git config --list…...