ASP.NET Core 与 ASPOSE.Words for .NET
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里面生成同样的列表和数据的例子。
建立项目
使用ASP.NET Core MVC 模板建立一个Web项目:

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


安装好之后,可以试用该产品。
安装许可
如果有授权许可的话,可以通过几种方式把它应用到该项目中,我喜欢的方式是使用文件:

把许可文件放在项目根目录,设置属性复制到输出文件夹: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文件生成在里面。
运行,文档已经生成成功:

其内容如下:

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

这里我设置表头的字体是加粗的,表格其它内容的字体是不加粗的。
表头的背景色是浅灰色的。
最后的效果如下:

ASP.NET Core 与 ASPOSE.Words for .NET的更多相关文章
- ASP.NET Core 之 Identity 入门(一)
前言 在 ASP.NET Core 中,仍然沿用了 ASP.NET里面的 Identity 组件库,负责对用户的身份进行认证,总体来说的话,没有MVC 5 里面那么复杂,因为在MVC 5里面引入了OW ...
- ASP.NET Core 中的那些认证中间件及一些重要知识点
前言 在读这篇文章之间,建议先看一下我的 ASP.NET Core 之 Identity 入门系列(一,二,三)奠定一下基础. 有关于 Authentication 的知识太广,所以本篇介绍几个在 A ...
- ASP.NET Core应用的错误处理[3]:ExceptionHandlerMiddleware中间件如何呈现“定制化错误页面”
DeveloperExceptionPageMiddleware中间件利用呈现出来的错误页面实现抛出异常和当前请求的详细信息以辅助开发人员更好地进行纠错诊断工作,而ExceptionHandlerMi ...
- ASP.NET Core MVC/WebAPi 模型绑定探索
前言 相信一直关注我的园友都知道,我写的博文都没有特别枯燥理论性的东西,主要是当每开启一门新的技术之旅时,刚开始就直接去看底层实现原理,第一会感觉索然无味,第二也不明白到底为何要这样做,所以只有当你用 ...
- ASP.NET Core应用的错误处理[2]:DeveloperExceptionPageMiddleware中间件如何呈现“开发者异常页面”
在<ASP.NET Core应用的错误处理[1]:三种呈现错误页面的方式>中,我们通过几个简单的实例演示了如何呈现一个错误页面,这些错误页面的呈现分别由三个对应的中间件来完成,接下来我们将 ...
- Asp.net Core中使用Session
前言 2017年就这么悄无声息的开始了,2017年对我来说又是特别重要的一年. 元旦放假在家写了个Asp.net Core验证码登录, 做demo的过程中遇到两个小问题,第一是在Asp.net Cor ...
- ASP.NET Core 中文文档 第四章 MVC(3.8)视图中的依赖注入
原文:Dependency injection into views 作者:Steve Smith 翻译:姚阿勇(Dr.Yao) 校对:孟帅洋(书缘) ASP.NET Core 支持在视图中使用 依赖 ...
- .NET跨平台之旅:将示例站点升级至 ASP.NET Core 1.1
微软今天在 Connect(); // 2016 上发布了 .NET Core 1.1 ,ASP.NET Core 1.1 以及 Entity Framework Core 1.1.紧跟这次发布,我们 ...
- ASP.NET Core HTTP 管道中的那些事儿
前言 马上2016年就要过去了,时间可是真快啊. 上次写完 Identity 系列之后,反响还不错,所以本来打算写一个 ASP.NET Core 中间件系列的,但是中间遇到了很多事情.首先是 NPOI ...
随机推荐
- LeetCode#1047-Remove All Adjacent Duplicates In String-删除字符串中的所有相邻重复项
一.题目 给出由小写字母组成的字符串 S,重复项删除操作会选择两个相邻且相同的字母,并删除它们. 在 S 上反复执行重复项删除操作,直到无法继续删除. 在完成所有重复项删除操作后返回最终的字符串.答案 ...
- SpringBoot系列(二)入门知识
SpringBoot系列(二)入门知识 往期推荐 SpringBoot系列(一)idea新建springboot项目 引言 本来新建springboot项目应该放在入门知识这一章的,但是由于新建spr ...
- Hadoop调试记录(2)
自从上次调通hbase后很久没有碰hadoop了,今日想写一个mapreduce的小程序.于是先运行了下自带的wordcount示例程序,却报错了. 信息如下: kevin@ubuntu:~/usr/ ...
- MySQL手工注入进阶篇——突破过滤危险字符问题
当我们在进行手工注入时,有时候会发现咱们构造的危险字符被过滤了,接下来,我就教大家如何解决这个问题.下面是我的实战过程.这里使用的是墨者学院的在线靶场.咱们直接开始. 第一步,判断注入点. 通过测试发 ...
- PTA | 1014 福尔摩斯的约会 (20分)
大侦探福尔摩斯接到一张奇怪的字条:我们约会吧! 3485djDkxh4hhGE 2984akDfkkkkggEdsb s&hgsfdk d&Hyscvnm.大侦探很快就明白了,字条上奇 ...
- 微信小程序将外部数据从父组件中传入到子组件
小程序组件开发遇到一个组件内嵌两个组件,而这两个子组件所使用的数据来自于同一个API,如下图所示. 如果这时候两个子组件各自导入同一个接口就会显得多余.另外的办法是由父组件导入接口数据,再从父组件将接 ...
- Hadoop(二)搭建Hadoop
0.部署计划 本文使用的版本是 red hat 6.8 -本来想用Centos7搭建的,但是工作需要还是换成这个了,不用红帽子用Centos 6系列的应该也可以 JDK 1.8 Hadoop 2.7. ...
- spring06
主要是学会spring中关于通过注释来配置bean. 以及处理怎样智选其一或者补选某一个bean还有就是关于当出现多个相同的bean的时候怎样配置: 具体的代码和配置文件如下: <?xml ve ...
- MTK Android Driver :Battery电池曲线
MTK Android Driver :battery电池曲线 1.配置文件位置: CUSTOM_KERNEL_BATTERY= battery mediatek\custom\\kernel\bat ...
- js定义类的方法
ECMAScript6已经支持了class,但之前版本都不支持类,但是可以通过一些方法来模拟类. js中的类,既是重点,也是难点,很多时候都感觉模棱两可. 首先强调一下js中很重要的3个知识点:thi ...