Modifiera VBA eller Makrokod med Aspose.Cells
Du kan ändra VBA- eller Makrokod med Aspose.Cells. Aspose.Cells har lagt till följande klasser för att läsa och ändra VBA-projektet i Excel-filen.
- VbaProject
- VbaModuleCollection
- VbaModule
Den här artikeln visar hur du ändrar VBA eller makrokoden inne i käll-Excel-filen med hjälp av Aspose.Cells.
Exempel
Följande provkod laddar käll-Excel-filen som har följande VBA- eller makrokod inuti den
Sub Button1_Click()
MsgBox "This is test message."
End Sub
Efter att Aspose.Cells provkoden har körts kommer VBA- eller makrokoden att modifieras på detta sätt
Sub Button1_Click()
MsgBox "This is Aspose.Cells message."
End Sub
Du kan ladda ner käll-excel-filen och output-excel-filen från de angivna länkarna.
// 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"); |