在 JavaScript 中将 PowerPoint 演示文稿转换为 Markdown

将 PowerPoint 转换为 Markdown

  1. 创建一个 Presentation 类的实例,以表示演示文稿对象。
  2. 使用 save 方法,将对象保存为 markdown 文件。

下面的 JavaScript 代码演示了如何将 PowerPoint 转换为 markdown:

var pres = new aspose.slides.Presentation("pres.pptx");
try {
    pres.save("pres.md", aspose.slides.SaveFormat.Md);
} finally {
    if (pres != null) {
        pres.dispose();
    }
}

将 PowerPoint 转换为 Markdown Flavor

Aspose.Slides 允许将 PowerPoint 转换为 markdown(包含基本语法)、CommonMark、GitHub flavored markdown、Trello、XWiki、GitLab 以及另外 17 种 markdown flavor。

下面的 JavaScript 代码演示了如何将 PowerPoint 转换为 CommonMark:

var pres = new aspose.slides.Presentation("pres.pptx");
try {
    var markdownSaveOptions = new aspose.slides.MarkdownSaveOptions();
    markdownSaveOptions.setFlavor(aspose.slides.Flavor.CommonMark);
    pres.save("pres.md", aspose.slides.SaveFormat.Md, markdownSaveOptions);
} finally {
    if (pres != null) {
        pres.dispose();
    }
}

受支持的 23 种 markdown flavor 列在 Flavor 枚举 中,可从 MarkdownSaveOptions 类获取。

将包含图像的演示文稿转换为 Markdown

MarkdownSaveOptions 类提供属性和枚举,可让您为生成的 markdown 文件使用特定选项或设置。例如,可将 MarkdownExportType 枚举设置为 SequentialTextOnlyVisual,以确定图像的渲染或处理方式。

顺序转换图像

如果希望图像在生成的 markdown 中逐个单独出现,需要选择 Sequential 选项。下面的 JavaScript 代码演示了如何将包含图像的演示文稿转换为 markdown:

var pres = new aspose.slides.Presentation("pres.pptx");
try {
    var markdownSaveOptions = new aspose.slides.MarkdownSaveOptions();
    markdownSaveOptions.setShowHiddenSlides(true);
    markdownSaveOptions.setShowSlideNumber(true);
    markdownSaveOptions.setFlavor(aspose.slides.Flavor.Github);
    markdownSaveOptions.setExportType(aspose.slides.MarkdownExportType.Sequential);
    markdownSaveOptions.setNewLineType(aspose.slides.NewLineType.Windows);
    pres.save("doc.md", java.newArray("int", [1, 2, 3, 4, 5, 6, 7, 8, 9]), aspose.slides.SaveFormat.Md, markdownSaveOptions);
} finally {
    if (pres != null) {
        pres.dispose();
    }
}

可视化转换图像

如果希望图像在生成的 markdown 中一起出现,需要选择 Visual 选项。此时,图像将保存到应用程序的当前目录(并在 markdown 文档中为其构建相对路径),也可以指定首选的路径和文件夹名称。

下面的 JavaScript 代码演示了该操作:

var pres = new aspose.slides.Presentation("pres.pptx");
try {
    final var outPath = "c:/documents";
    var markdownSaveOptions = new aspose.slides.MarkdownSaveOptions();
    markdownSaveOptions.setExportType(aspose.slides.MarkdownExportType.Visual);
    markdownSaveOptions.setImagesSaveFolderName("md-images");
    markdownSaveOptions.setBasePath(outPath);
    pres.save("pres.md", aspose.slides.SaveFormat.Md, markdownSaveOptions);
} finally {
    if (pres != null) {
        pres.dispose();
    }
}

FAQ

超链接在导出为 Markdown 时会被保留吗?

会。文本超链接会被保留为标准 Markdown 链接。幻灯片切换动画则不会被转换。

可以通过多线程运行来加快转换速度吗?

可以对文件进行并行处理,但不要在多个线程之间共享同一个 Presentation 实例。请为每个文件使用独立的实例或进程,以避免竞争。

图像会怎样处理——保存到哪里,路径是相对的吗?

图像会导出到专用文件夹,Markdown 文件默认使用相对路径引用它们。您可以配置基础输出路径和资源文件夹名称,以保持可预测的仓库结构。