KeepPageStreamOpen
内容
[
隐藏
]PageSavingArgs.KeepPageStreamOpen property
指定 Aspose.Words 在保存文档页面后是否应保持流打开或关闭它。
public bool KeepPageStreamOpen { get; set; }
评论
默认为错误的
Aspose.Words 将关闭您提供的流 PageStream
将文档页面写入其中后的属性。 指定真的
以保持流打开。
例子
演示如何使用回调将文档逐页保存为 HTML。
public void PageFileNames()
{
Document doc = new Document();
DocumentBuilder builder = new DocumentBuilder(doc);
builder.Writeln("Page 1.");
builder.InsertBreak(BreakType.PageBreak);
builder.Writeln("Page 2.");
builder.InsertImage(ImageDir + "Logo.jpg");
builder.InsertBreak(BreakType.PageBreak);
builder.Writeln("Page 3.");
// 创建一个“HtmlFixedSaveOptions”对象,我们可以将其传递给文档的“Save”方法
// 修改我们将文档转换为 HTML 的方式。
HtmlFixedSaveOptions htmlFixedSaveOptions = new HtmlFixedSaveOptions();
// 我们将把这个文档中的每个页面保存到本地文件系统中的一个单独的 HTML 文件中。
// 设置一个回调,允许我们命名每个输出 HTML 文档。
htmlFixedSaveOptions.PageSavingCallback = new CustomFileNamePageSavingCallback();
doc.Save(ArtifactsDir + "SavingCallback.PageFileNames.html", htmlFixedSaveOptions);
string[] filePaths = Directory.GetFiles(ArtifactsDir).Where(
s => s.StartsWith(ArtifactsDir + "SavingCallback.PageFileNames.Page_")).OrderBy(s => s).ToArray();
Assert.AreEqual(3, filePaths.Length);
}
/// <summary>
/// 将所有页面保存到其中指定的文件和目录中。
/// </summary>
private class CustomFileNamePageSavingCallback : IPageSavingCallback
{
public void PageSaving(PageSavingArgs args)
{
string outFileName = $"{ArtifactsDir}SavingCallback.PageFileNames.Page_{args.PageIndex}.html";
// 以下是指定 Aspose.Words 保存文档每一页的位置的两种方法。
// 1 - 设置输出页面文件的文件名:
args.PageFileName = outFileName;
// 2 - 为输出页面文件创建自定义流:
args.PageStream = new FileStream(outFileName, FileMode.Create);
Assert.False(args.KeepPageStreamOpen);
}
}
也可以看看
- class PageSavingArgs
- 命名空间 Aspose.Words.Saving
- 部件 Aspose.Words