-
C# 冻结Excel窗口以锁定行列、或解除冻结
在处理大型Excel工作簿时,有时候我们需要在工作表中冻结窗格,这样可以在滚动查看数据的同时保持某些行或列固定不动。冻结窗格可以帮助我们更容易地导航和理解复杂的数据集。相反,当你不需要冻结窗格时,你可能需要解冻它们以获得完整的视野。
下面将介绍如何使用免费.NET库通过C#实现冻结Excel窗口以锁定行和列,以及如何解除冻结。
免费.NET Excel库:
本文提供的实现方案需要用到 Free Spire.XLS for .NET 这个免费库。该库可以在 .NET 应用程序中快速实现对 Excel 文档的各种操作。可以通过Nuget直接安装,或者下载后手动引用Dll。
PM> Install-Package FreeSpire.XLS
C# 冻结Excel窗口(冻结首行、首列、多行多列)
Free Spire.XLS for .NET免费库提供了 Worksheet.FreezePanes(int rowIndex, int columnIndex) 方法来冻结Excel行和列。其中的两个参数:
- rowIndex: 表示行的索引 (索引从1开始),在该行之上的所有行将被冻结。
- columnIndex: 表示列的索引(索引从1开始),在该列左边的所有列将被冻结。
因此,要冻结首行即为FreezePanes(2, 1),冻结首列为FreezePanes(1, 2),同时冻结首行首列为FreezePanes(2, 2),以此类推。
以下为冻结Excel行或列的C#示例代码:
using Spire.Xls; namespace FreezeTopRow { class Program { static void Main(string[] args) { //加载Excel文档 Workbook workbook = new Workbook(); workbook.LoadFromFile(@"C:\Users\Administrator\Desktop\测试.xlsx"); //获取第一张工作表 Worksheet sheet = workbook.Worksheets[0]; //冻结首行 sheet.FreezePanes(2, 1); //冻结首列 //sheet.FreezePanes(1, 2); //冻结首行首列 //sheet.FreezePanes(2, 2); //冻结前三行 //sheet.FreezePanes(4, 1); //保存文件 workbook.SaveToFile("冻结Excel行列.xlsx", ExcelVersion.Version2016); } } }
C# 解除冻结Excel行和列
要解除冻结,直接使用 Worksheet.RemovePanes() 方法即可,示例代码如下:
using Spire.Xls; namespace UnfreezeExcelPane { class Program { static void Main(string[] args) { //加载Excel文件 Workbook workbook = new Workbook(); workbook.LoadFromFile("冻结行列.xls"); //获取第一张工作表 Worksheet sheet = workbook.Worksheets[0]; //解冻工作表中的行或列 sheet.RemovePanes(); //保存文件 workbook.SaveToFile("解冻Excel行列.xlsx", ExcelVersion.Version2016); } } }
出处:https://www.cnblogs.com/Yesi/p/18136075
栏目列表
最新更新
python爬虫及其可视化
使用python爬取豆瓣电影短评评论内容
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
uniapp/H5 获取手机桌面壁纸 (静态壁纸)
[前端] DNS解析与优化
为什么在js中需要添加addEventListener()?
JS模块化系统
js通过Object.defineProperty() 定义和控制对象
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比