DevExpress Office File API使用记录

目录

    • [1 RichEditorControl控件不包含Save类型事件](#1 RichEditorControl控件不包含Save类型事件)
    • [2 Document和SubDocument关系](#2 Document和SubDocument关系)
    • [3 如何在类库中使用DevExpress Office File API](#3 如何在类库中使用DevExpress Office File API)
    • [4 测试Demo创建记录](#4 测试Demo创建记录)
      • [4.1 创建类库](#4.1 创建类库)
      • [4.2 创建Winform项目](#4.2 创建Winform项目)

1 RichEditorControl控件不包含Save类型事件

2 Document和SubDocument关系

Document和SubDocument都是interface,SubDocument是Document基类,SubDocument定义了基本功能,Document在其基础上定义了特定功能,在正文的处理中,只能使用Document对象,针对页眉页脚的操作,使用SubDocument对象,可保证适用于正文的那些操作不会误操作到页眉页脚。

3 如何在类库中使用DevExpress Office File API

1.添加Nuget包:DevExpress.Document.Processor

DevExpress.RichEdit.Core

2.示例代码:

复制代码
/// <summary>
/// 文档打开/保存/编辑
/// </summary>
public class DocumentService : IReportEditor, IDisposable
{
  private readonly RichEditDocumentServer _server;

  public DocumentService()
  {
    _server = new RichEditDocumentServer();
  }

  /// <summary>
  /// 打开 Word 文档,返回可编辑的文档流
  /// </summary>
  /// <param name="filePath"></param>
  /// <returns></returns>
  public Task<Stream> OpenDocumentAsync(string filePath)
  {
    return Task.Run(() =>
    {
      _server.LoadDocument(filePath);
      var stream = new MemoryStream();
      _server.SaveDocument(stream, DocumentFormat.OpenXml);
      stream.Position = 0;
      return (Stream)stream;
    });
  }

  /// <summary>
  /// 从流创建新文档
  /// </summary>
  /// <returns></returns>
  public Task<Stream> CreateNewAsync()
  {
    return Task.Run(() =>
    {
      _server.CreateNewDocument();
      var stream = new MemoryStream();
      _server.SaveDocument(stream, DocumentFormat.OpenXml);
      stream.Position = 0;
      return (Stream)stream;
    });
  }
  /// <summary>
  /// 保存文档
  /// </summary>
  /// <param name="documentStream"></param>
  /// <param name="savePath"></param>
  /// <returns></returns>
  public Task SaveDocumentAsync(Stream documentStream, string savePath)
  {
    return Task.Run(() =>
    {
      documentStream.Position = 0;
      _server.LoadDocument(documentStream, DocumentFormat.OpenXml);
      _server.SaveDocument(savePath, DocumentFormat.OpenXml);
    });
  }

  /// <summary>
  /// 导出为 PDF
  /// </summary>
  /// <param name="documentStream"></param>
  /// <param name="pdfPath"></param>
  /// <returns></returns>
  public Task ExportToPdfAsync(Stream documentStream, string pdfPath)
  {
    return Task.Run(() =>
    {
      documentStream.Position = 0;
      _server.LoadDocument(documentStream, DocumentFormat.OpenXml);
      _server.ExportToPdf(pdfPath);
    });
  }

  public void Dispose()
  {
    _server?.Dispose();
  }
}

4 测试Demo创建记录

4.1 创建类库

  1. 创建类库项目,目标框架:.NET Standard 2.1
  2. 在项目中引入包:DevExpress.Document.Processor、DevExpress.RichEdit.Core和DevExpress.Xpo
  3. 创建4个文件夹:Blazor(Blazor网站使用)、Common(公共类,平台无关)、Models(实体对象类)、Win(Winform窗体应用使用)
  4. 在Models文件夹下创建TReportData类,用以保存报告数据
  5. 在Win文件夹下创建TReportEditorWin类,用以和窗体类应用程序交互
  6. 在TReportEditorWin类中添加域函数插入方法(InsertVariableField)和加载数据方法(LoadData)
  7. 添加TReportTemplet数据实体保存模板二进制流数据
  8. 在TReportEditorWin类中添加模板二进制流保存和获取方法
  9. 在TReportEditorWin类中添加除指定域函数外其他部分不可编辑的设置方法ProtectDocumentExceptFields

4.2 创建Winform项目

  1. 创建窗体项目,目标框架:.NET 8.0(注:DevExpress项目)
  2. 主界面设置一系列功能按钮,不同的按钮打开不同的界面
  3. 模板编辑界面使用RichEditControl加CreateAllTabs,在右侧留出一小块位置模拟域函数数据列表
  4. 在模板编辑界面初始化时:初始化模拟自定义域函数及其拖拽事件,左键点击选择域函数行并拖动,拖到RichEditor编辑区域松开,将域函数插入到鼠标光标处
  5. 在模板编辑界面加载报告模板时,会将报告模板的二进制流数据保存到数据库中
  6. 添加报告编辑界面,用来加载模板,合并数据,进行报告信息编辑
  7. 在报告编辑界面调用ProtectDocumentExceptFields设置报告那些部分可编辑(目前整个文档禁止编辑,尚未处理)
相关推荐
hez20101 天前
在 .NET 上构建超大托管数组
c#·.net·.net core·gc·clr
雨落倾城夏未凉7 天前
第四章c#方法-参数数组和可选参数(16)
后端·c#
唐青枫8 天前
线程不是越多越快:C#.NET Thread 生命周期、同步与后台工作线程实战
c#·.net
唐青枫9 天前
别只会反射:C#.NET Emit 动态生成代码实战详解
c#·.net
咕白m6259 天前
.NET 环境下 Word 超链接批量提取方案
c#·.net
用户91721561902119 天前
C# 通信协议增量解析:用状态机处理半包和粘包
c#
小码编匠10 天前
C# 工控上位机必备:数据转换工具类与十个核心模块
后端·c#·.net
唐青枫12 天前
别再乱用 StartNew:C#.NET TaskFactory 任务调度实战详解
c#·.net
Artech12 天前
[MAF预定义的AIContextProvider-03]ChatHistoryMemoryProvider——赋予Agent从经验中学习的能力
ai·c#·agent·memory·maf
Scout-leaf14 天前
C#摸鱼实录——IoC与DI案例详解
c#