Spire.Doc 生成pdf业务运营报告
需求:每天向全国各运营大区钉钉运营群定时发送pdf业务运营报告;
通过对各Office操作组件对比,选择Spire.Doc。它专门为开发人员进行创建,读取,写入、转换打印 word 文档文件提供便利,不需要安装 MS Office即可对 word、Excel、Pdf 进行操作。包含商业版与免费版,其中免费版对文档页数有限制(Free version is limited to 500 paragraphs and 25 tables. This limitation is enforced during reading or writing files. When converting word documents to PDF and XPS files, you can only get the first 3 page of PDF file.)。官方地址:https://www.e-iceblue.com/
组件安装
- 打开Visual Studio ,选择 “工具" -->”NuGet包管理器“ -->”程序包管理控制台“
- 输入:Install-Package FreeSpire.Doc -Version 7.1.13
- 其中:可安装的历史版本可参见:https://www.nuget.org/packages/FreeSpire.Doc, 如下图:

常用操作
1、加载Word模板
Document document = new Document();
document.LoadFromFile("sample.docx", FileFormat.Docx);
2 、获取模板中的表格
//获取第一个节
Section section = document.Sections[]; //获取第一个表格,若模板中有多个表格,则序号从0开始依次顺延
Table table = section.Tables[] as Table;
3、表格行列操作
//添加一行到表格的最后
table.AddRow(true, ); //插入一行到表格的第三行
table.Rows.Insert(, table.AddRow()); //添加一列到表格,设置单元格的宽度和宽度类型
for (int i = ; i < table.Rows.Count; i++)
{
TableCell cell = table.Rows[i].AddCell(true);
cell.Width = table[, ].Width;
cell.CellWidthType = table[, ].CellWidthType;
} //删除第二行
table.Rows.RemoveAt(); //删除第二列
for (int i = ; i < table.Rows.Count; i++)
{
table.Rows[i].Cells.RemoveAt();
} //设置第一行的行高
table.Rows[].Height = ; //设置第二列的列宽
for (int i = ; i < table.Rows.Count; i++)
{
table.Rows[i].Cells[].Width = ;
}
4、表格单元格赋值及样式
//添加第1行
TableRow row1 = table.AddRow(); //添加第1个单元格到第1行
TableCell cell1 = row1.AddCell();
cell1.AddParagraph().AppendText("姓 名"); //添加第2个单元格到第1行
TableCell cell2 = row1.AddCell();
cell2.AddParagraph().AppendText("年 龄"); //设置表格的第二行第一列水平居左
table[, ].Paragraphs[].Format.HorizontalAlignment = HorizontalAlignment.Left; //设置表格第二行第一列垂直居上
table[,].CellFormat.VerticalAlignment = VerticalAlignment.Top; //设置第二行第一个单元格的背景颜色
table[,].CellFormat.BackColor = Color.SeaGreen; //通过 TextRange.CharacterFormat 来设置单元格内文本属性,如:阴影,字体、颜色等
TextRange HText = paragraph.AppendText("this is a test!");
HText.CharacterFormat.IsShadow = true;
HText.CharacterFormat.FontSize = ;
5、表格样式
/获取第一个表格
Table table = section.Tables[] as Table; //给表格应用内置样式
table.ApplyStyle(DefaultTableStyle.LightGridAccent3); //设置表格的上边框
table.TableFormat.Borders.Top.BorderType = BorderStyle.Double;
table.TableFormat.Borders.Top.LineWidth = 1.0F;
table.TableFormat.Borders.Top.Color = Color.YellowGreen; //设置第一行的背景颜色
table.Rows[].RowFormat.BackColor = Color.SeaGreen; //设置第一行第一个单元格的背景颜色
table[,].CellFormat.BackColor = Color.SeaGreen;当word模板中的表格由Excel画好后,粘贴至Word,然后再读取模板中的表格时,上面的这些样式设置好象未起作用,待验证
6、写操作
//文档转换
ocument document = new Document(); document.LoadFromFile("sample.doc");
document.SaveToFile("result.html", FileFormat.Html);
document.Close(); ocument.LoadFromFile("sample.html", FileFormat.Html, XHTMLValidationType.None);
document.SaveToFile("result.doc");
document.Close(); //其它文件的转换类似总结:对于Table表格的操作与DataTable操作很类似,在每个单元格内 AddParagraph() 支持增加不同的Range类型,如:文本、超链、表格嵌套等,这块的处理又与DevExpress控件的表格操作很类似,很赞,要是开源就更棒!
应用开发步骤
- 新建Word报告模板,包括变量、表格等,模板中的表格,我是在Excel中画好后复制过来的,如下图:

- NuGet安装Spire.Doc组件
- 加载Word模板,获取业务数据填充表格
- 保存pdf文档,免费组件只能最多3页数据,因此在定义Word模板时,将文档长宽设置为文档允许的最大高度,以便于显示更多的内容
- 示例应用效果如下图:

- 文档中设置的联查,可以在数据填充的过程中设置联查到你的业务系统,联查的设置参见上一节的第4小节,单元格内的paragraph允许向其内添加不同的控件,如:文本、图片、超链、复选框等,点击联查应用效果如下图(当然你得控制访问权限):

- 生成报告是本需求的核心,你可以将生成的文档保存至指定的Web站点对应的目录下,然后建立钉钉机器人,定时发送消息,消息体指定为一个http地址即可,应用效果如下图:

参考文档
- 帮助文档: http://e-iceblue.cn/spiredoc/word-conversion-feature.html
- 安装: https://www.nuget.org/packages/FreeSpire.Doc
Spire.Doc 生成pdf业务运营报告的更多相关文章
- Spire.DOC生成表格测试
首先,很感谢Jack对我的信任,让我来写一个评测,在此对Jack说一声抱歉,由于本人愚钝,并且最近项目比较紧张,把评测这个事情脱了一个月之久,由于往后的日子可能更忙,所以今晚抽空只能只写了一个小程序来 ...
- java生成PDF,各种格式、样式、水印都有
代码中有两处需要图片,请自行替换. 一个是水印.一个是手指. 需要的JAR包链接:http://download.csdn.net/detail/justinytsoft/9688893 下面是预览: ...
- C# html生成PDF遇到的问题,从iTextSharp到wkhtmltopdf
我们的网站业务会生成一个报告,用网页展示出来,要有生成pdf并下载的功能,关键是生成pdf. 用内容一段段去拼pdf,想想就很崩溃,所以就去网上找直接把html生成pdf的方法. 网上资料大部分都是用 ...
- 利用Java动态生成 PDF 文档
利用Java动态生成 PDF 文档,则需要开源的API.首先我们先想象需求,在企业应用中,客户会提出一些复杂的需求,比如会针对具体的业务,构建比较典型的具备文档性质的内容,一般会导出PDF进行存档.那 ...
- 使用Spire.Doc来转换文本
使用Spire.Doc来转换文本 前段时间,我为不熟悉这个产品的读者们写了一篇关于我对 Spire.Doc的初识印象.Spire.Doc是一个专业的Word .NET库,它是专门为开发人员设计的用来快 ...
- Spire.Doc组件读取与写入Word
之前写了一篇开源组件DocX读写word的文章,当时时间比较匆忙选了这个组件,使用过程中还是有些不便,不能提前定义好模版,插入Form表单域进行替换.最近无意中发现Spire.Doc组件功能很强大,目 ...
- 如何从Windows Phone 生成PDF文档
我需要从我的Windows Phone应用程序生成PDF. 遗憾的是没有标准的免费的PDF生成库在Windows Phone上运行. 我不得不自己生成PDF,通过直接写入到文件格式. 这竟然是真的很容 ...
- C#生成PDF页脚第几页共几页
C#生成PDF页脚第几页共几页 分类: .net 2012-06-06 21:04 2842人阅读 评论(3) 收藏 举报 c#stringfontsfileheaderwindows 我在网上找了好 ...
- C#使用Spire.Doc Word for .Net读写Word
以前对Excel或Word文档操作都使用微软的COM组件Microsoft Word 15.0 object library. 但是这种方式必须要求服务器上安装Office,而且会出现读写操作完成后未 ...
随机推荐
- 【Linux】Linux环境变量的设置和查看
Linux的变量种类 按变量的生存周期来划分,Linux变量可分为两类: 1 永久的:需要修改配置文件,变量永久生效. 2 临时的:使用export命令声明即可,变量在关闭shell时失效. 设置变量 ...
- C#-DllImport 路径问题
原文:C# DllImport 相对路径无法找到dll DllImport DLL查找顺序:1.应用程序所在目录2.Windows目录和Windows\System32目录3.环境变量目录 只需要你把 ...
- 查找算法(5)--Tree table lookup--树表查找
1.树表查找 (1) 最简单的树表查找算法——二叉树查找算法. [1]基本思想:二叉查找树是先对待查找的数据进行生成树,确保树的左分支的值小于右分支的值,然后在就行和每个节点的父节点比较大小,查找最适 ...
- 泡泡一分钟:Context-Aware Modelling for Augmented Reality Display Behaviour
张宁 Context-Aware Modelling for Augmented Reality Display Behaviour链接:https://pan.baidu.com/s/1RpX6kt ...
- 【bat批处理】批量执行某个文件夹下的所有sql文件bat批处理
遍历文件夹下所有的sql文件,然后命令行执行 for /r "D:\yonyou\UBFV60\U9.VOB.Product.Other" %%a in (*.sql) do ( ...
- mysql 5.7开启sql日志的配置
今天把数据库换成了5.7的,想查通过sql日志定位下问题,但是发现和以前的方式不一样了,特意记录下来 通过开启mysql的日志功能,可以记录所有别执行过的sql语句记录,便于维护数据库数据. 在数据库 ...
- [转] 浅谈 OpenResty
一.前言 我们都知道Nginx有很多的特性和好处,但是在Nginx上开发成了一个难题,Nginx模块需要用C开发,而且必须符合一系列复杂的规则,最重要的用C开发模块必须要熟悉Nginx的源代码,使得开 ...
- phpmyadmin 显示被隐藏的表
点击后,会把这个表隐藏掉.有时候误点会莫名其妙. 点击数据库上的眼睛,能够显示被隐藏的表.
- [转帖]OLTP、OLAP与HTAP
OLTP.OLAP与HTAP https://blog.csdn.net/ZG_24/article/details/87854982 OLTP On-Line Transaction Proce ...
- [转帖]超能课堂(207) SD卡标准错综复杂,到底该认哪一个?
超能课堂(207)SD卡标准错综复杂,到底该认哪一个? https://www.expreview.com/71505.html 开始的地方 SD容量等级 SD标准(SDSC) SDHC SDXC S ...