Attribuer un code macro à un contrôle de formulaire
Contents
[
Hide
]
Aspose.Cells vous permet d’attribuer un code macro à un contrôle de formulaire comme un bouton. Veuillez utiliser la méthode ShapeCollection.addShape() pour attribuer un nouveau code macro à un contrôle de formulaire dans le classeur.
Attribuer un code macro à un contrôle de formulaire en utilisant Aspose.Cells
Le code d’exemple suivant crée un nouveau classeur, attribue un code macro à un bouton de formulaire et enregistre la sortie au format XLSM. Une fois que vous ouvrirez le fichier XLSM de sortie dans Microsoft Excel, vous verrez le code macro suivant.
Sub ShowMessage()
MsgBox "Welcome to Aspose!"
End Sub
Voici un code d’exemple pour générer le fichier de sortie XLSM avec du code Macro.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// For complete examples and data files, please go to https://github.com/aspose-cells/Aspose.Cells-for-Java | |
// The path to the documents directory. | |
String dataDir = Utils.getDataDir(AssignMacroToFormControl.class); | |
Workbook workbook = new Workbook(); | |
Worksheet sheet = workbook.getWorksheets().get(0); | |
int moduleIdx = workbook.getVbaProject().getModules().add(sheet); | |
VbaModule module = workbook.getVbaProject().getModules().get(moduleIdx); | |
module.setCodes("Sub ShowMessage()" + "\r\n" + | |
" MsgBox \"Welcome to Aspose!\"" + "\r\n" + | |
"End Sub"); | |
Button button = (Button) sheet.getShapes().addShape(MsoDrawingType.BUTTON, 2, 0, 2, 0, 28, 80); | |
button.setPlacement(PlacementType.FREE_FLOATING); | |
button.getFont().setName("Tahoma"); | |
button.getFont().setBold(true); | |
button.getFont().setColor(Color.getBlue()); | |
button.setText("Aspose"); | |
button.setMacroName(sheet.getName() + ".ShowMessage"); | |
workbook.save(dataDir + "Output.xlsm"); | |
System.out.println("File saved"); |