通过 VBA 的演示文稿

添加 VBA 宏

Aspose.Slides 提供了 VbaProject 类,允许您创建 VBA 项目(以及项目引用)并编辑现有模块。您可以使用 VbaProject 类来管理嵌入在演示文稿中的 VBA。

  1. 创建 Presentation 类的实例。
  2. 使用 VbaProject 构造函数添加新的 VBA 项目。
  3. 向 VbaProject 添加模块。
  4. 设置模块的源代码。
  5. 添加对 的引用。
  6. 添加对 Microsoft Office 的引用。
  7. 将这些引用关联到 VBA 项目。
  8. 保存演示文稿。

以下 JavaScript 代码演示了如何从头向演示文稿添加 VBA 宏:

// 创建演示文稿类的实例
let pres = new aspose.slides.Presentation();
try {
    // 创建新的 VBA 项目
    pres.setVbaProject(new aspose.slides.VbaProject());
    // 向 VBA 项目添加一个空模块
    let module = pres.getVbaProject().getModules().addEmptyModule("Module");
    // 设置模块的源代码
    module.setSourceCode("Sub Test(oShape As Shape)MsgBox Test End Sub");
    // 创建对 <stdole> 的引用
    let stdoleReference = new aspose.slides.VbaReferenceOleTypeLib("stdole", "*\\G{00020430-0000-0000-C000-000000000046}#2.0#0#C:\\Windows\\system32\\stdole2.tlb#OLE Automation");
    // 创建对 Office 的引用
    let officeReference = new aspose.slides.VbaReferenceOleTypeLib("Office", "*\\G{2DF8D04C-5BFA-101B-BDE5-00AA0044DE52}#2.0#0#C:\\Program Files\\Common Files\\Microsoft Shared\\OFFICE14\\MSO.DLL#Microsoft Office 14.0 Object Library");
    // 向 VBA 项目添加引用
    pres.getVbaProject().getReferences().add(stdoleReference);
    pres.getVbaProject().getReferences().add(officeReference);
    // 保存演示文稿
    pres.save("test.pptm", aspose.slides.SaveFormat.Pptm);
} finally {
    if (pres != null) {
        pres.dispose();
    }
}

删除 VBA 宏

使用 Presentation 类下的 VbaProject 属性,您可以删除 VBA 宏。

  1. 创建 Presentation 类的实例并加载包含宏的演示文稿。
  2. 访问 Macro 模块并将其删除。
  3. 保存已修改的演示文稿。
// 加载包含宏的演示文稿
let pres = new aspose.slides.Presentation("VBA.pptm");
try {
    // 访问 Vba 模块并将其移除
    pres.getVbaProject().getModules().remove(pres.getVbaProject().getModules().get_Item(0));
    // 保存演示文稿
    pres.save("test.pptm", aspose.slides.SaveFormat.Pptm);
} finally {
    if (pres != null) {
        pres.dispose();
    }
}

提取 VBA 宏

  1. 创建 Presentation 类的实例并加载包含宏的演示文稿。
  2. 检查演示文稿是否包含 VBA 项目。
  3. 遍历 VBA 项目中包含的所有模块以查看宏。

以下 JavaScript 代码演示了如何从包含宏的演示文稿中提取 VBA 宏:

// 加载包含宏的演示文稿
let pres = new aspose.slides.Presentation("VBA.pptm");
try {
    // 检查演示文稿是否包含 VBA 项目
    if (pres.getVbaProject() != null) {
        for (let i = 0; i < pres.getVbaProject().getModules().size(); i++) {
            let module = pres.getVbaProject().getModules().get_Item(i);
            console.log(module.getName());
            console.log(module.getSourceCode());
        }
    }
} finally {
    if (pres != null) {
        pres.dispose();
    }
}

检查 VBA 项目是否受密码保护

使用 VbaProject.isPasswordProtected 方法,您可以判断项目的属性是否受密码保护。

  1. 创建 Presentation 类的实例并加载包含宏的演示文稿。
  2. 检查演示文稿是否包含 VBA project
  3. 检查 VBA 项目是否受密码保护以查看其属性。
let presentation = new aspose.slides.Presentation("VBA.pptm");
try {
    if (presentation.getVbaProject() != null) { // 检查演示文稿是否包含 VBA 项目。
        if (presentation.getVbaProject().isPasswordProtected()) {
            console.log("The VBA Project '%s' is protected by password to view project properties.", 
                    presentation.getVbaProject().getName());
        }
    }
} finally {
    presentation.dispose();
}

常见问题

如果我将演示文稿另存为 PPTX,宏会怎样?

宏会被移除,因为 PPTX 不支持 VBA。若要保留宏,请选择 PPTM、PPSM 或 POTM。

Aspose.Slides 能在演示文稿内部运行宏,例如刷新数据吗?

不能。该库从不执行 VBA 代码;只有在 PowerPoint 中且拥有相应安全设置时才能执行。

是否支持使用与 VBA 代码关联的 ActiveX 控件?

是的,您可以访问现有的 ActiveX controls,修改其属性并将其移除。当宏与 ActiveX 交互时,这非常有用。