Modifica del codice VBA o Macro utilizzando Aspose.Cells
È possibile modificare il codice VBA o Macro utilizzando Aspose.Cells. Aspose.Cells ha aggiunto le seguenti classi per leggere e modificare il progetto VBA nel file Excel.
- VbaProject
- VbaModuleCollection
- VbaModule
Questo articolo ti mostrerà come modificare il codice VBA o Macro all’interno del file Excel di origine usando Aspose.Cells.
Esempio
Il seguente codice di esempio carica il file Excel di origine che contiene il seguente codice VBA o Macro al suo interno
Sub Button1_Click()
MsgBox "This is test message."
End Sub
Dopo l’esecuzione del codice di esempio di Aspose.Cells, il codice VBA o Macro sarà modificato in questo modo
Sub Button1_Click()
MsgBox "This is Aspose.Cells message."
End Sub
È possibile scaricare il file Excel di origine e il file Excel di output dai link forniti.
// 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"); |