ASPOSE.Cells & ASPOSE.Words 操纵Excel和Word文档的 .NET Core 实例

Aspose.Total是Aspose公司旗下的最全的一套office文档管理方案,它提供的原生API能够对Word、Excel、PDF、Powerpoint、Outlook、CAD、图片、3D、ZIP等超过100多种文件格式进行操做,还具备报表、二维码、GIS、任务等功能,可使用C#(.NET/.NET Core/Mono/Xamarin...)、Java、Android、C++、Nodejs、PHP、Python等语言。字体

 

下面我使用ASP.NET Core MVC 作一个从Excel文件读取列表数据,并生成一个Word文档,同时在Word里面生成一样的列表和数据的例子。ui

创建项目

使用ASP.NET Core MVC 模板创建一个Web项目:3d

 

安装 Aspose.Cells 和 Aspose.Words

而后经过Nuget安装Aspose.Cells 和 Aspose.Words包,分别负责Excel和Word文档的操纵:code

安装好以后,能够试用该产品。对象

 

安装许可

若是有受权许可的话,能够经过几种方式把它应用到该项目中,我喜欢的方式是使用文件:blog

把许可文件放在项目根目录,设置属性复制到输出文件夹:Copy if newer。索引

 

在 Program.cs里,添加如下代码,完成许可的设置:接口

 

运行,若是能输出如下内容,说明许可安装成功了:图片

 

 读取Excel

为了方便,我直接把要读取的Excel文件放在项目根目录下:文档

 

 

 其内容以下:

 

打开HomeController,在Privacy方法里进行实现,也就是我点击Privacy菜单的时候,会读取该Excel文件的内容并生成一个Word文档:

加载Excel文件

Aspose.Cells容许你使用多种方式加载Excel文件,这里我直接使用文件路径的方式:

 

能够看到,一个Excel文件就是一个Workbook。而数据呢,实际是放在不一样sheet(工做簿)里面,因此还须要锁定sheet。

Workbook里面有个属性叫Worksheets,它的类型是WorksheetCollection,是一个集合,而这个集合实现了IList<T>接口,因此能够经过索引的方式访问它的元素。

获取第一个sheet:

 

读取单元格里的数据

如今就能够读取单元格里的数据了。

可使用单元格的名称,例如 A2;或者行和列的索引等方式来访问单元格。

为了方便存储列表的数据,我创建了一个类,它的属性对应列表的列:

 

而后我使用行列索引的方式来读取单元格的内容,并把内容存放到一个List里面,并传递到View:

 

 下面是View的代码:

 

 运行程序,点击Privacy:

能够看到数据从Excel文件里成功的被读取了。

 

写入Word文档 

在Aspose里面,Word文档对应的是Document对象。

在Document里面写内容,就须要使用DocumentBuilder:

剩下的就是模拟咱们平时操做Word的一个过程。

首先我须要一个剧中的,字号较大的一个标题。我先设置字体,而后设置段落:

这里字体是24号大,加粗,宋体,蓝色,没有下划线。

而后建立了一个段落,剧中的。

最后写了一行文字。

 

建立表格

建立表格首先须要调用DocumentBuilder.StartTable.方法,而后使用DocumentBuilder.InsertCell来插入单元格,使用 DocumentBuilder.EndRow来结束每一行,最后使用DocumentBuilder.EndTable来结束这个表格。

整个代码就像咱们手绘表格同样:

这里,首先我须要把字体改变成表格所需的大小。

而后开始一个格一个格的写入内容。

最后,在把table的宽度设为自适应窗口宽度。而后结束表格便可。

 

生成Word文件

生成Word文档的方式也是多种多样的,我这里直接生成文件:

这里面我注入了IWebHostEnvironment,用它找到项目根目录,而后把Word文件生成在里面。

 

运行,文档已经生成成功:

 

其内容以下:

目前还差一个表头,因此我添加以下代码:

这里我设置表头的字体是加粗的,表格其它内容的字体是不加粗的。

表头的背景色是浅灰色的。

 

最后的效果以下:

相关文章
相关标签/搜索