.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文档中,最后在输出来. ...
随机推荐
- 【读书笔记】组合计数-Tilings-引言部分
Tilings-引言部分 目录 一些形式化定义 各种各样的Tilings例子 Example 9.1.1 Example 9.1.2 Example 9.1.3 Thurston and Lagari ...
- java多线程--6 死锁问题 锁Lock
java多线程--6 死锁问题 锁Lock 死锁问题 多个线程互相抱着对方需要的资源,然后形成僵持 死锁状态 package com.ssl.demo05; public class DeadLock ...
- Django笔记五之字段类型
这篇笔记介绍字段的类型 Field Type. Django 的model 下的 field 对应的是 MySQL 中的表字段,而我们定义的 field 的类型则对应 MySQL 中的字段类型. 本次 ...
- SpringBoot的EnableCaching简述
Spring Boot中的EnableCaching简述 spring boot中自带有数据缓存机制,主要通过其org.springframework.cache包下的各种类来实现. EnableCa ...
- API网关:开源Apinto网关快速入门
Apinto网关基于GO语言模块化开发,5分钟极速部署,配置简单.易于维护,支持集群与动态扩容,开箱即用.Apinto除了提供丰富的网关插件外,还提供监控告警.用户角色等扩展应用,同时支持自定义网关插 ...
- 全网最详细中英文ChatGPT-GPT-4示例文档-事实性回答应用从0到1快速入门——官网推荐的48种最佳应用场景(附python/node.js/curl命令源代码,小白也能学)
目录 Introduce 简介 setting 设置 Prompt 提示 Sample response 回复样本 API request 接口请求 python接口请求示例 node.js接口请求示 ...
- python---滚动条操作
""" 1.让元素滚动到可见区域后,再操作.(大部分的网页自己会滚,直接找元素---下一页) drive.find_element("id",&quo ...
- C语言结构体大小分析
title: C语言结构体大小分析 author: saopigqwq233 date: 2022-04-05 C语言结构体大小分析 一,基本类型 C语言自带的数据类型大小如下 数据类型 大小(字节) ...
- 动态开点线段树&线段树合并学习笔记
动态开点线段树 使用场景 \(4 \times n\) 开不下. 值域需要平移(有负数). 什么时候开点 显然,访问的节点不存在时(只会在修改递归时开点). trick 区间里面有负数时,\(mid ...
- Java线程创建
程序.进程.线程 程序:指令和数据的有序集合,静态 进程:程序的一次执行过程,动态,系统分配资源的单位 线程:一个进程可以包含多个线程,一个进程至少有一个线程,线程是CPU调度的基本单位 线程创建 三 ...