Modificar el Código VBA o Macro utilizando Aspose.Cells
Puede modificar el Código VBA o Macro utilizando Aspose.Cells. Aspose.Cells ha agregado las siguientes clases para leer y modificar el proyecto VBA en el archivo de Excel.
- VbaProject
- VbaModuleCollection
- VbaModule
Este artículo te mostrará cómo cambiar el código de VBA o macro dentro del archivo de Excel fuente utilizando Aspose.Cells.
Ejemplo
El siguiente código de ejemplo carga el archivo de Excel fuente que contiene el siguiente código de VBA o macro.
Sub Button1_Click()
MsgBox "This is test message."
End Sub
Después de la ejecución del código de ejemplo de Aspose.Cells, el código de VBA o macro será modificado de la siguiente manera
Sub Button1_Click()
MsgBox "This is Aspose.Cells message."
End Sub
Puedes descargar el archivo de Excel fuente y el archivo de Excel de salida desde los enlaces proporcionados.
// For complete examples and data files, please go to https://github.com/aspose-cells/Aspose.Cells-for-Java | |
String dataDir = Utils.getDataDir(ModifyVBAorMacroCode.class); | |
// Create workbook object from source Excel file | |
Workbook workbook = new Workbook(dataDir + "sample.xlsm"); | |
// Change the VBA Module Code | |
VbaModuleCollection modules = workbook.getVbaProject().getModules(); | |
for (int i = 0; i < modules.getCount(); i++) { | |
VbaModule module = modules.get(i); | |
String code = module.getCodes(); | |
// Replace the original message with the modified message | |
if (code.contains("This is test message.")) { | |
code = code.replace("This is test message.", "This is Aspose.Cells message."); | |
module.setCodes(code); | |
} | |
} | |
// Save the output Excel file | |
workbook.save(dataDir + "output.xlsm"); |