VbaModuleCollection

VbaModuleCollection class

代表集合VbaModule对象.

要了解更多信息,请访问使用 VBA 宏文档文章。

public sealed class VbaModuleCollection : IEnumerable<VbaModule>

特性

姓名描述
Count { get; }返回集合中 VBA 模块的数量。
Item { get; }检索VbaModule按索引的对象. (2 indexers)

方法

姓名描述
Add(VbaModule)将模块添加到集合中。
Remove(VbaModule)从集合中删除指定的模块。

例子

演示如何访问文档的 VBA 项目信息。

Document doc = new Document(MyDir + "VBA project.docm");

// VBA 项目包含 VBA 模块的集合。
VbaProject vbaProject = doc.VbaProject;
Console.WriteLine(vbaProject.IsSigned
    ? $"Project name: {vbaProject.Name} signed; Project code page: {vbaProject.CodePage}; Modules count: {vbaProject.Modules.Count()}\n"
    : $"Project name: {vbaProject.Name} not signed; Project code page: {vbaProject.CodePage}; Modules count: {vbaProject.Modules.Count()}\n");

VbaModuleCollection vbaModules = doc.VbaProject.Modules; 

Assert.AreEqual(vbaModules.Count(), 3);

foreach (VbaModule module in vbaModules)
    Console.WriteLine($"Module name: {module.Name};\nModule code:\n{module.SourceCode}\n");

// 为 VBA 模块设置新的源代码。您可以通过索引或名称访问集合中的 VBA 模块。
vbaModules[0].SourceCode = "Your VBA code...";
vbaModules["Module1"].SourceCode = "Your VBA code...";

// 从集合中删除一个模块。
vbaModules.Remove(vbaModules[2]);

也可以看看