• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >ASP.NET > .NET读写Excel工具Spire.Xls使用 Excel文件的控制(2)

.NET读写Excel工具Spire.Xls使用 Excel文件的控制(2)

作者: 字体:[增加 减小] 来源:互联网 时间:2018-08-20

通过本文主要向大家介绍了.NET,Excel,Spire.Xls等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

前一篇文章:“ .NET操作Excel利器Spire.Xls使用(1)入门介绍 ”给大家介绍了Spire.XLS的基本功能和一些比较。这篇文章将重点介绍C#操作Excel文件时,对Excel文件本身的相关设置,全局控制的内容。因为这也是C#读写Excel文件时经常碰到的文章,也是我在使用过程中的一个学习步骤。本文将首先介绍Spire.XLS创建和加载文档的基础知识,以及文件保存,多个Excel文件合并的操作方法,其中我们还可以对生成的Excel文件做更多详细的设置,如,对Excel文件属性进行设置等等,其次很多项目中,不仅要生成Excel文件,还需要打印并获取一些分页信息;最后介绍一下使用C#设置加密保护Excel文件的方法。

1.Excel文档的创建、加载与保存

  我们的上一篇文章的初步介绍中,有一个Hello Excel的例子,其实就已经包括了Excel文件新建和保存的方法,非常简单。这一节将着重对每个细节进行更详细点的研究。

1.1 保存Excel文件

  Excle文件的保存都是使用Workbook的SaveToFile方法,有以下几个版本,可以根据自己的需要,根据文件名,Excel文件版本,以及文件格式来保存,方法原型如下,比较简单不再演示,在后续的文章中会在代码中用到。

//根据文件名,文件版本,文件格式信息来保存文件
public void SaveToFile(string fileName);
public void SaveToFile(string fileName, ExcelVersion version);
public void SaveToFile(string fileName, FileFormat fileFormat);
public void SaveToFile(string fileName, string separator);

1.2 从不同途径加载Excel

  使用C#操作Excel文件,不一定都是生成Excel文件报表之类的,有时候也需要加载已经存在的数据(XML,Excle等)来进行修改,然后保存到对应的Excel文件中去。加载到Excel的方法是Workbook对象的LoadFromFile、LoadFromStream、LoadFromXml等方法,方法原型有以下几个:

//从文件加载,根据文件名,保护模式和Excel版本
public void LoadFromFile(string fileName);
public void LoadFromFile(string fileName, bool preserveMode);
public void LoadFromFile(string fileName, ExcelVersion version);
public void LoadFromFile(string fileName, string separator);
public void LoadFromFile(string fileName, string separator, int row, int column);
public void LoadFromFile(string fileName, string separator, int row, int column, ExcelVersion version);
//从数据流中加载
public void LoadFromStream(Stream stream);
public void LoadFromStream(Stream stream, bool loadStyles);
public void LoadFromStream(Stream stream, ExcelVersion version);
//从XML文件加载
public void LoadFromXml(Stream stream);
public void LoadFromXml(string fileName);
//从模版文件加载
public void LoadTemplateFromFile(string fileName);
public void LoadTemplateFromFile(string fileName, bool loadStyles);

2.C#设置Excel文件属性

  文件属性这个虽然一般人很少用到,但还是介绍一下,毕竟如果文件分发出去的话,将相关属性信息添加完整,还是很有必要的。Excel文件属性可以点击文件右键-属性看到界面,如下图我使用WPS查看的Excel文件属性,使用Office Excel查看的话,是右边的样子,虽然显示不一样,但原理是一样的:


1.WPS显示的Excel属性                                        2.Office Excle显示的文件属性

  设置Excel文件属性的方法在Workbook对象的DocumentProperties属性中,这个属性是一个XlsBuiltInDocumentProperties类型,在Spire.Xls.Core.Spreadsheet.Collections命名空间,通过VS的对象浏览器也可以发现其实现的一些原理,可以扩展到其他的组件使用中。看看一个简单的例子:

#region 2.Excel文件属性例子
static void ExcelTest2()
{   
 Workbook workbook = new Workbook();

 //修改文档属性信息,这样在发布的时候,可以通过文档显示公司以及文件人的信息
 workbook.DocumentProperties.Author = "张三";   //作者
 workbook.DocumentProperties.Subject = "测试文件属性"; //主题
 workbook.DocumentProperties.Title = "测试Excel文件"; //标题
 workbook.DocumentProperties.Company = "XX有限公司";  //单位
 workbook.DocumentProperties.Comments = "保留文件评论"; //评论
 workbook.DocumentProperties.Keywords = "测试 Excel "; //关键词
 workbook.DocumentProperties.CreatedTime = DateTime.Now; //创建时间
 //TODO:还有其他属性,可以参考XlsBuiltInDocumentProperties的相关属性   

 //将Excel文件保存到指定文件,还可以指定Excel版本
 workbook.SaveToFile("Sample.xls", ExcelVersion.Version2007);
}
#endregion

  注意,由于我没有安装Office 2007及以上版本,用WPS显示的时候,有点问题,要用WPS转换为2003版本后才能看出来,这可能是WPS的原因,调试生成的文件发现,这些属性值都是存在的。所以我也没去折腾,安装个Office 真的很麻烦。

3.C#加密和保护Excel文件

  相信很多人都用过Office的加密以及保护功能,对于Excel来说,加密和保护的范围更加广泛了:不仅可以加密文件,还可以保护指定的Sheet,指定的单元格等等。

3.1 加密Excel文件

  Excel文件级的加密其实很简单,就是Workbook对象的Protect方法,传递加密密码即可;如果想要取消密码,则使用workbook.UnProtect(),注意取消加密是不需要密码的,Excel软件操作也是的,所以程序操作也不需要。

#region 3.加密Excel文件例子
static void ExcelTest3()
{
 Workbook workbook = new Workbook();
 workbook.Protect("pwd111");//设置保护加密的 密码 :pwd111
 //将Excel文件保存
 workbook.SaveToFile("Sample.xls", ExcelVersion.Version2007);
}
#endregion

加密后打开文件就是这个样子了:

3.2 保护Sheet与单元格

   Sheet的保护更加灵活一点,使用的是Worksheet对象的Protect方法,传递的参数是 保护的密码,以及可选的保护类型(更加丰富的保护类型),看看下面的例子:

Workbook workbook = new Workbook();

Worksheet sheet = workbook.Worksheets[0];

//保护sheet
sheet.Protect("test", SheetProtectionType.All);

//将Excel文件保存
workbook.SaveToFile("Sample.xlsx", ExcelVersion.Version2010);

实现的效果应该和WPS的“保护工作表”界面类似,如下图:

保护工作表的作用一般是防止误操作或者对于有版权保护的,不能轻易更改的情况。大家看情况使用,我这里很少用到,只是了解到了,顺便说一下。

static void ExcelTest4()
{
 Workbook workbook = new Workbook();
 workbook.CreateEmptySheets(1);
 Worksheet sheet = workbook.Worksheets[0];

 sheet.Range["A1"].Text = "锁定";
 sheet.Range["B1"].Text = "未锁定";

 sheet.Range["A1"].Style.Locked = true;
 sheet.Range["B1"].Style.Locked = false;

 //一定要对工作表进行保护,才能生效
 sheet.Protect("test", SheetProtectionType.All);

 workbook.SaveToFile(@"Sample_Lock.xlsx", ExcelVersion.Version2010);
}

  今天就到此为止把,虽然都很简单,但了解一下,对以后熟练开发还是有好处的。例子非常简单,代码都在上面,到本系列完成后,再打包一份代码。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • Asp.net SignalR 应用并实现群聊功能 开源代码
  • asp.net动态更新
  • asp.net利用母版制作页脚效果
  • Asp.Net服务器发送HTTP标头后无法设置内容类型的问题解决
  • 使用asp.net mvc,boostrap及knockout.js开发微信自定义菜单编辑工具(推荐)
  • 详解ASP.NET MVC 常用扩展点:过滤器、模型绑定
  • ASP.NET Core发送邮件的方法
  • 在ASP.NET Core 中发送邮件的实现方法(必看篇)
  • ASP.NET MVC从视图传参到控制器的几种形式
  • .net core使用redis基于StackExchange.Redis

相关文章

  • 2017-05-11.NET MD5加密解密代码解析
  • 2017-05-11ASP.NET oledb连接Access数据库的方法
  • 2017-05-11详解ASP.NET MVC之下拉框绑定四种方式
  • 2017-05-11asp.net Linq to Xml学习笔记
  • 2017-05-11Microsoft Visual Studio 2010下如何添加命令提示行
  • 2017-05-11Visual Studio调试技巧汇总
  • 2017-05-11wireshark抓取本地回环数据包和取出数据的方法
  • 2018-08-20在.NET中扫描局域网服务的实现方法
  • 2017-05-11asp.net 按字节检查包含全半角的文字
  • 2017-05-11Visual Studio.Net 内幕(6)

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • asp.net 更改gridview pageSize的方法
    • ASP.NET实现二维码(QRCode)的创建和读取实例
    • asp.net显示自己的网页图标的几种方式
    • Asp.net 字符串操作基类(安全,替换,分解等)
    • 从请求管道深入剖析HttpModule的实现机制图文介绍
    • ASP.NET站点导航应用详解
    • FileStreaReder和StreamReader两个类介绍
    • DropDownList 下拉框选择改变促发事件和防全局刷新(推荐)
    • 解读ASP.NET 5 & MVC6系列教程(12):基于Lamda表达式的强类型Routing实现
    • 使用 Visual Studio 的“代码度量值”来改进代码质量

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有