Trabalhando com macros VBA
Visual Basic for Applications (VBA) para Microsoft Word é uma linguagem de programação simples, mas poderosa, que pode ser usada para estender a funcionalidade. Aspose.Words API fornece três classes para obter acesso ao código-fonte do projeto VBA:
- A classe VBAProject fornece acesso às informações do projeto VBA
- A classe VBAModuleCollection retorna a coleção de módulos do projeto VBA
- A classe VbaModule fornece acesso ao módulo do projeto VBA
- A enumeração VbaModuleType define os tipos de modelo em um projeto VBA. O módulo pode ser um módulo processual, módulo de documento, módulo de classe ou módulo de designer
Crie um projeto VBA
Aspose.Words API fornece a propriedade VbaProject para obter ou definir VbaProject no documento.
O exemplo de código a seguir demonstra como criar um projeto VBA e um módulo VBA junto com propriedades básicas, por exemplo, nome e tipo:
| // For complete examples and data files, please go to https://github.com/aspose-words/Aspose.Words-for-.NET | |
| Document doc = new Document(); | |
| // Create a new VBA project. | |
| VbaProject project = new VbaProject(); | |
| project.Name = "AsposeProject"; | |
| doc.VbaProject = project; | |
| // Create a new module and specify a macro source code. | |
| VbaModule module = new VbaModule(); | |
| module.Name = "AsposeModule"; | |
| module.Type = VbaModuleType.ProceduralModule; | |
| module.SourceCode = "New source code"; | |
| // Add module to the VBA project. | |
| doc.VbaProject.Modules.Add(module); | |
| doc.Save(dataDir + "VbaProject_out.docm"); |
Ler macros
Aspose.Words também oferece aos usuários a capacidade de ler macros VBA.
O exemplo de código a seguir mostra como ler macros VBA do documento:
| // For complete examples and data files, please go to https://github.com/aspose-words/Aspose.Words-for-.NET | |
| Document doc = new Document(dataDir + "Document.dot"); | |
| if (doc.VbaProject != null) | |
| { | |
| foreach (VbaModule module in doc.VbaProject.Modules) | |
| { | |
| Console.WriteLine(module.SourceCode); | |
| } | |
| } |
Escreva ou modifique macros
Usando Aspose.Words, os usuários podem modificar macros VBA.
O exemplo de código a seguir mostra como modificar macros VBA usando a propriedade SourceCode:
| // For complete examples and data files, please go to https://github.com/aspose-words/Aspose.Words-for-.NET | |
| Document doc = new Document(dataDir + "test.docm"); | |
| VbaProject project = doc.VbaProject; | |
| const string newSourceCode = "Test change source code"; | |
| // Choose a module, and set a new source code. | |
| project.Modules[0].SourceCode = newSourceCode; |
Clonar projeto VBA
Com Aspose.Words também é possível clonar projetos VBA.
O exemplo de código a seguir mostra como clonar o projeto VBA usando a propriedade Clone que cria uma cópia do projeto existente:
| // For complete examples and data files, please go to https://github.com/aspose-words/Aspose.Words-for-.NET | |
| Document doc = new Document(dataDir + "VbaProject_source.docm"); | |
| VbaProject project = doc.VbaProject; | |
| Document destDoc = new Document(); | |
| // Clone the whole project. | |
| destDoc.VbaProject = doc.VbaProject.Clone(); | |
| destDoc.Save(dataDir + "output.docm"); |
Clonar módulo VBA
Você também pode clonar módulos VBA, se necessário.
O exemplo de código a seguir mostra como clonar o módulo VBA usando a propriedade Clone que cria uma cópia do projeto existente:
| // For complete examples and data files, please go to https://github.com/aspose-words/Aspose.Words-for-.NET | |
| Document doc = new Document(dataDir + "VbaProject_source.docm"); | |
| VbaProject project = doc.VbaProject; | |
| Document destDoc = new Document(); | |
| destDoc.VbaProject = new VbaProject(); | |
| // Clone a single module. | |
| VbaModule copyModule = doc.VbaProject.Modules["Module1"].Clone(); | |
| destDoc.VbaProject.Modules.Add(copyModule); | |
| destDoc.Save(dataDir + "output.docm"); |
Trabalhe com as referências do projeto VBA
Aspose.Words API fornece a classe VbaReferenceCollection para trabalhar com referências de projetos VBA que representam uma coleção de referências de projetos VBA.
O exemplo de código a seguir mostra como remover algumas referências da coleção de referências de um projeto VBA:
| // For complete examples and data files, please go to https://github.com/aspose-words/Aspose.Words-for-.NET | |
| Document doc = new Document(dataDir + "VbaProject.docm"); | |
| // Find and remove the reference with some LibId path. | |
| const string brokenPath = "brokenPath.dll"; | |
| VbaReferenceCollection references = doc.VbaProject.References; | |
| for (int i = references.Count - 1; i >= 0; i--) | |
| { | |
| VbaReference reference = doc.VbaProject.References.ElementAt(i); | |
| string path = GetLibIdPath(reference); | |
| if (path == brokenPath) | |
| references.RemoveAt(i); | |
| } | |
| doc.Save(dataDir + "NoBrokenRef.docm"); |
| // For complete examples and data files, please go to https://github.com/aspose-words/Aspose.Words-for-.NET | |
| /// <summary> | |
| /// Returns string representing LibId path of a specified reference. | |
| /// </summary> | |
| private static string GetLibIdPath(VbaReference reference) | |
| { | |
| switch (reference.Type) | |
| { | |
| case VbaReferenceType.Registered: | |
| case VbaReferenceType.Original: | |
| case VbaReferenceType.Control: | |
| return GetLibIdReferencePath(reference.LibId); | |
| case VbaReferenceType.Project: | |
| return GetLibIdProjectPath(reference.LibId); | |
| default: | |
| throw new ArgumentOutOfRangeException(); | |
| } | |
| } | |
| /// <summary> | |
| /// Returns path from a specified identifier of an Automation type library. | |
| /// </summary> | |
| /// <remarks> | |
| /// Please see details for the syntax at [MS-OVBA], 2.1.1.8 LibidReference. | |
| /// </remarks> | |
| private static string GetLibIdReferencePath(string libIdReference) | |
| { | |
| if (libIdReference != null) | |
| { | |
| string[] refParts = libIdReference.Split('#'); | |
| if (refParts.Length > 3) | |
| return refParts[3]; | |
| } | |
| return ""; | |
| } | |
| /// <summary> | |
| /// Returns path from a specified identifier of an Automation type library. | |
| /// </summary> | |
| /// <remarks> | |
| /// Please see details for the syntax at [MS-OVBA], 2.1.1.12 ProjectReference. | |
| /// </remarks> | |
| private static string GetLibIdProjectPath(string libIdProject) | |
| { | |
| return (libIdProject != null) ? libIdProject.Substring(3) : ""; | |
| } |