.Net Aspose.Words 生成Word文档
.Net Aspose.Words 生成Word文档
在开发WinForm项目中,有一需求要生成Word文档,百度学习,记录一下实现方法
NuGet包,找到 Aspose.Words 安装 21.8.0或以下 版本,否则高版本即使执行了注册码也会提示过期
一.新建一个基类
using Aspose.Words;
using Aspose.Words.Tables;
using System;
using System.Collections.Generic;
using System.Data;
using System.Drawing;
using System.IO; namespace DataBrowser.Common
{
/// <summary>
/// 生成word文档
/// </summary>
public class ExportOutWord
{
public ExportOutWord()
{
//需要在启动程序中执行注册码,否则生成的Word文档会有水印。
new Aspose.Words.License().SetLicense(new MemoryStream(Convert.FromBase64String(
"PExpY2Vuc2U+CiAgPERhdGE+CiAgICA8TGljZW5zZWRUbz5TdXpob3UgQXVuYm94IFNvZnR3YXJlIENvLiwgTHRkLjwvTGl" +
"jZW5zZWRUbz4KICAgIDxFbWFpbFRvPnNhbGVzQGF1bnRlYy5jb208L0VtYWlsVG8+CiAgICA8TGljZW5zZVR5cGU+RGV2ZW" +
"xvcGVyIE9FTTwvTGljZW5zZVR5cGU+CiAgICA8TGljZW5zZU5vdGU+TGltaXRlZCB0byAxIGRldmVsb3BlciwgdW5saW1pd" +
"GVkIHBoeXNpY2FsIGxvY2F0aW9uczwvTGljZW5zZU5vdGU+CiAgICA8T3JkZXJJRD4yMDA2MDIwMTI2MzM8L09yZGVySUQ+" +
"CiAgICA8VXNlcklEPjEzNDk3NjAwNjwvVXNlcklEPgogICAgPE9FTT5UaGlzIGlzIGEgcmVkaXN0cmlidXRhYmxlIGxpY2V" +
"uc2U8L09FTT4KICAgIDxQcm9kdWN0cz4KICAgICAgPFByb2R1Y3Q+QXNwb3NlLlRvdGFsIGZvciAuTkVUPC9Qcm9kdWN0Pg" +
"ogICAgPC9Qcm9kdWN0cz4KICAgIDxFZGl0aW9uVHlwZT5FbnRlcnByaXNlPC9FZGl0aW9uVHlwZT4KICAgIDxTZXJpYWxOd" +
"W1iZXI+OTM2ZTVmZDEtODY2Mi00YWJmLTk1YmQtYzhkYzBmNTNhZmE2PC9TZXJpYWxOdW1iZXI+CiAgICA8U3Vic2NyaXB0" +
"aW9uRXhwaXJ5PjIwMjEwODI3PC9TdWJzY3JpcHRpb25FeHBpcnk+CiAgICA8TGljZW5zZVZlcnNpb24+My4wPC9MaWNlbnN" +
"lVmVyc2lvbj4KICAgIDxMaWNlbnNlSW5zdHJ1Y3Rpb25zPmh0dHBzOi8vcHVyY2hhc2UuYXNwb3NlLmNvbS9wb2xpY2llcy" +
"91c2UtbGljZW5zZTwvTGljZW5zZUluc3RydWN0aW9ucz4KICA8L0RhdGE+CiAgPFNpZ25hdHVyZT5wSkpjQndRdnYxV1NxZ" +
"1kyOHFJYUFKSysvTFFVWWRrQ2x5THE2RUNLU0xDQ3dMNkEwMkJFTnh5L3JzQ1V3UExXbjV2bTl0TDRQRXE1aFAzY2s0WnhE" +
"ejFiK1JIWTBuQkh1SEhBY01TL1BSeEJES0NGbWg1QVFZRTlrT0FxSzM5NVBSWmJRSGowOUNGTElVUzBMdnRmVkp5cUhjblJ" +
"vU3dPQnVqT1oyeDc4WFE9PC9TaWduYXR1cmU+CjwvTGljZW5zZT4=")));
}
/// <summary>
/// 生成文档
/// </summary>
public void GenerateWord(string savePath)
{
//过程:实例化得到word模板文件,编辑模板文件内容,再另存为新的word文件 string filePath = AppDomain.CurrentDomain.BaseDirectory + "UploadFile\\报告模板.docx";
Document doc = new Document(filePath); //这里我是放了一个空的模板,要注意得到的文件路径是绝对路径
DocumentBuilder builder = new DocumentBuilder(doc); builder.ParagraphFormat.StyleIdentifier = StyleIdentifier.BodyText; #region 第一页 AddContent(builder, "微软雅黑", true, 15, Color.Red, ParagraphAlignment.Left, "涉密资料"); Wrap(builder, 5); //换行 AddContent(builder, "微软雅黑", false, 24, Color.Black, ParagraphAlignment.Center, "标题一"); Wrap(builder, 1);
AddContent(builder, "微软雅黑", false, 24, Color.Black, ParagraphAlignment.Center, "标题二"); Wrap(builder, 1);
AddContent(builder, "微软雅黑", false, 24, Color.Black, ParagraphAlignment.Center, "标题三"); Wrap(builder, 4); AddContent(builder, "微软雅黑", false, 15.5, Color.Black, ParagraphAlignment.Center, DateTime.Now.ToString("yyyy.MM.dd")); #endregion builder.InsertBreak(BreakType.PageBreak); //新增页 #region 第二页 AddContent(builder, "宋体", true, 15.5, Color.Black, ParagraphAlignment.Left, "一、 报告背景"); AddContent(builder, "宋体", true, 12, Color.Black, ParagraphAlignment.Left, "1. 政策依据"); AddContent(builder, "宋体", false, 12, Color.Black, ParagraphAlignment.Left, "本报告所引用的相关政策依据为:",
24, 18); Wrap(builder, 1); AddContent(builder, "宋体", true, 12, Color.Black, ParagraphAlignment.Left, "2. 数据范围"); AddContent(builder, "宋体", false, 12, Color.Black, ParagraphAlignment.Left, "本报告使用数据来源于",
24, 18); #endregion builder.InsertBreak(BreakType.PageBreak); //新增页 #region 第三页 AddContent(builder, "宋体", true, 15.5, Color.Black, ParagraphAlignment.Left, "二、 涉嫌问题及描述"); AddContent(builder, "宋体", true, 12, Color.Black, ParagraphAlignment.Left, "1. XXX问题"); AddContent(builder, "宋体", false, 12, Color.Black, ParagraphAlignment.Left, "分析结果如下:",
24, 18); InsertTable(builder, "select row_number() over(order by Id) as 序号, [ItemName] 项目名称, [ItemMoney] [金额(元)], [ItemNum] [数量] from ViolationStatistics"); #endregion doc.Save(savePath);
} /// <summary>
/// 添加内容
/// </summary>
/// <param name="builder"></param>
/// <param name="fontName">字体的名称</param>
/// <param name="bold">字体是否加粗</param>
/// <param name="size">字体大小</param>
/// <param name="color">字体颜色</param>
/// <param name="alignment">对齐方式</param>
/// <param name="content">内容</param>
/// <param name="firstLineIndent">首行缩进</param>
/// <param name="lineSpacing">行距</param>
/// <param name="spaceBefore">段前行距</param>
/// <param name="spaceAfter">段后行距</param>
public void AddContent(DocumentBuilder builder, string fontName, bool bold, double size, Color color,
ParagraphAlignment alignment, string content, double firstLineIndent = 0,
double lineSpacing = 12, double spaceBefore = 0, double spaceAfter = 6)
{
builder.Font.Name = fontName; //字体的名称
builder.Font.Bold = bold; //字体加粗
builder.Font.Size = size; //字体大小
builder.Font.Color = color; //字体颜色
builder.ParagraphFormat.Alignment = alignment; //对齐方式
builder.ParagraphFormat.FirstLineIndent = firstLineIndent; //首行缩进
builder.ParagraphFormat.LineSpacing = lineSpacing; //行距
builder.ParagraphFormat.SpaceBefore = spaceBefore; //段前行距
builder.ParagraphFormat.SpaceAfter = spaceAfter; //段后行距
builder.Writeln(content);
} /// <summary>
/// 换行
/// </summary>
/// <param name="builder"></param>
public void Wrap(DocumentBuilder builder, int rowNum)
{
builder.Font.Size = 10.5;
builder.ParagraphFormat.Alignment = ParagraphAlignment.Left;
for (int i = 0; i < rowNum; i++)
{
builder.Writeln("");
}
} #region 添加表格(直接从数据库DataTable数据插入生成表格) public void InsertTable(DocumentBuilder builder, string sql)
{
List<string> listCol = new List<string>(); //表头
List<string> listText = new List<string>(); //行数据 DataTable dt = SqlHelper.ExecuteDataSet(sql).Tables[0];
foreach (DataColumn col in dt.Columns)
{
listCol.Add(col.ColumnName);//获取到DataColumn列对象的列名
} //文档中插入表格
Table table = builder.StartTable();
builder.RowFormat.Borders.Color = Color.Black; //插入表头
InsertCell(builder, listCol, true, 1);
//渲染数据
for (int i = 0; i < dt.Rows.Count; i++)
{
listText = new List<string>();
foreach (string ss in listCol)
{
listText.Add(dt.Rows[i][ss].ToString());
}
InsertCell(builder, listText, false, i % 2);
}
builder.EndTable();
//自动使表格适合单元格内容
table.AutoFit(AutoFitBehavior.AutoFitToContents);
//表格居中对齐
table.Alignment = TableAlignment.Center;
} public void InsertCell(DocumentBuilder builder, List<string> ArrText, bool bold, int a)
{
builder.ParagraphFormat.Alignment = ParagraphAlignment.Center; //对齐方式
builder.ParagraphFormat.FirstLineIndent = 0; //首行缩进
builder.ParagraphFormat.SpaceAfter = 0; //段后行距
builder.ParagraphFormat.LineSpacing = 12; //行距
builder.Font.Size = 11;
builder.Font.Name = "宋体";
builder.Font.Bold = bold;
for (int i = 0; i < ArrText.Count; i++)
{
builder.InsertCell();
builder.CellFormat.Width = 100;
builder.CellFormat.VerticalAlignment = CellVerticalAlignment.Center; //隔行修改背景颜色
if (a == 0)
{
builder.CellFormat.Shading.BackgroundPatternColor = Color.FromArgb(198, 217, 241);
}
else
{
builder.CellFormat.Shading.BackgroundPatternColor = Color.White;
}
builder.Write(ArrText[i]);
}
builder.EndRow();
} #endregion
}
}
二、获取存储路径并执行
private void btn_screport_Click(object sender, EventArgs e)
{
SaveFileDialog sfd = new SaveFileDialog();
string PlatName = "分析报告"; //1.打开保存窗口,自定义文件保存位置
sfd.Filter = "(*.docx)|*.docx";
sfd.FileName = PlatName + DateTime.Now.ToString("yyyyMMddHHmmss");
sfd.ShowDialog();
string saveFilePath = sfd.FileName; //获取本地指定的存储路径 ExportOutWord exportOutWord = new ExportOutWord();
exportOutWord.GenerateWord(saveFilePath);
}
.Net Aspose.Words 生成Word文档的更多相关文章
- Aspose.Words简单生成word文档
Aspose.Words简单生成word文档 Aspose.Words.Document doc = new Aspose.Words.Document(); Aspose.Words.Documen ...
- ASP.NET生成WORD文档,服务器部署注意事项
网上转的,留查备用,我服务器装的office2007所以修改的是Microsoft Office word97 - 2003 文档这一个. ASP.NET生成WORD文档服务器部署注意事项 1.Asp ...
- POI生成WORD文档
h2:first-child, body>h1:first-child, body>h1:first-child+h2, body>h3:first-child, body>h ...
- PowerDesigner将PDM导出生成WORD文档
PowerDesigner将PDM导出生成WORD文档 环境 PowerDesigner15 1.点击Report Temlates 制作模板 2.如果没有模板,单击New图标创建.有直接双击进入. ...
- velocity模板技术生成word文档
本文介绍採用velocity技术在Java中生成word文档的方法. 1.新建一个word文档,编辑内容例如以下: 2.将上述word文档另存为htm格式的文件 3.新建一个Java Project项 ...
- 使用C#动态生成Word文档/Excel文档的程序测试通过后,部署到IIS服务器上,不能正常使用的问题解决方案
使用C#动态生成Word文档/Excel文档的程序功能调试.测试通过后,部署到服务器上,不能正常使用的问题解决方案: 原因: 可能asp.net程序或iis访问excel组件时权限不够(Ps:Syst ...
- 用php生成word文档
一.用windows里面自带的com,然后用php生成word文档 <?php $word= new COM("word.application") or die(" ...
- c#生成word文档
参考:http://blog.163.com/zhouchunping_99/blog/static/7837998820085114394716/ 生成word文档 生成word文档 view pl ...
- 将HTML导出生成word文档
前言: 项目开发中遇到了需要将HTML页面的内容导出为一个word文档,所以有了这边随笔. 当然,项目开发又时间有点紧迫,第一时间想到的是用插件,所以百度了下.下面就介绍两个导出word文档的方法. ...
- POI生成word文档完整案例及讲解
一,网上的API讲解 其实POI的生成Word文档的规则就是先把获取到的数据转成xml格式的数据,然后通过xpath解析表单式的应用取值,判断等等,然后在把取到的值放到word文档中,最后在输出来. ...
随机推荐
- 什么是Redis持久化,如何理解?
其实redis就是一种高级的以键值对形式存储数据的数据库,而它的好处就是他可以支持数据的持久化,其实redis之所以会有这样的优点,主要是因为,redis的数据都是存放在内存中的,如果不配置持久化,那 ...
- 解决class path resource [applicationContext.xml] cannot be opened because it does not exist
在学习spring的过程出现class path resource [applicationContext.xml] cannot be opened because it does not exis ...
- MYSQL 最左匹配原则的原理
https://blog.csdn.net/Andrew_Chenwq/article/details/125242197最左匹配原则最左匹配原则就是指在联合索引中,如果你的 SQL 语句中用到了联合 ...
- noopener, noreferrer 及 nofollow 的用法
<a> 标签通常会配合着使用 noopener, noreferrer 及 nofollow 这些属性, 它们的作用及用法如下. noopener 当给链接加上 target=" ...
- Windows 11 Update Download Error Solution - 0x80248007
I had the same issue on a Windows 2019 virtual server while performing routine windows updates. The ...
- 【装饰器设计模式详解】C/Java/JS/Go/Python/TS不同语言实现
简介 装饰器模式(Decorator Pattern)是一种结构型设计模式.将对象放入到一个特殊封装的对象中,为这个对象绑定新的行为,具备新的能力,同时又不改变其原有结构. 如果你希望在无需修改代码的 ...
- k8s集群进行删除并添加node节点
在已建立好的k8s集群中删除节点后,进行添加新的节点,可参考用于添加全新node节点,若新的node需要安装docker和k8s基础组件. 建立集群可以参考曾经的文章:CentOS8 搭建Kubern ...
- pysimplegui之元素常用属性
常用元素参数 您将在几乎所有元素创建调用中看到的一些参数包括: key - 与 window[key].事件和返回值字典一起使用 工具提示tooltip - 将鼠标悬停在元素上,您将获得包含此文本的弹 ...
- LeeCode 1832 找出游戏的获胜者
LeeCode 1832 题目描述: 共有 n 名小伙伴一起做游戏.小伙伴围成一圈,按顺时针顺序从1到n编号.确切地说,从第 i 名小伙伴顺时针移动一位会到达第 (i+1) 名小伙伴的位置,其中 1 ...
- visio秘钥
一.Visio2016专业版永久激活码: Visio 2016 Professional Retail零售版 [Key]:NKVJM-8MTT4-8YDFR-6738M-DPFJH [Key]:W9W ...