Visual Basic for Applications
Visual Basic for Applications (VBA) est une implémentation de Microsoft Visual Basic qui est intégrée dans toutes les applications de Microsoft Office, dans quelques autres applications Microsoft comme Visio et au moins partiellement dans quelques autres applications comme AutoCAD, WordPerfect, MicroStation, Solidworks ou encore ArcGIS. Il remplace et étend les capacités des langages macro spécifiques aux plus anciennes applications comme le langage WordBasic intégré à une ancienne version du logiciel Word, et peut être utilisé pour contrôler la quasi-totalité de l'IHM des applications hôtes, ce qui inclut la possibilité de manipuler les fonctionnalités de l'interface utilisateur comme les menus, et de personnaliser les boîtes de dialogue et les formulaires utilisateurs.
Visual Basic for Applications | |
Date de première version | 1993 |
---|---|
Paradigme | Impératif, événementiel |
Développeur | Microsoft |
Dernière version | 7.1.1100 (Office 2013) |
Typage | Hybride statique/dynamique |
Influencé par | Visual Basic |
Licence | Logiciel propriétaire |
Comme son nom l'indique, VBA est très lié à Visual Basic (les syntaxes et concepts des deux langages se ressemblent), mais ne peut normalement qu'exécuter du code dans une application hôte Microsoft Office (et non pas d'une application autonome, il requiert donc une licence de la suite bureautique Microsoft). Il peut cependant être utilisé pour contrôler une application à partir d'une autre (par exemple, créer automatiquement un document Word à partir de données Excel). Le code ainsi exécuté est stocké dans des instances de documents, on l'appelle également macro.
VBA est fonctionnellement riche et extrêmement flexible, mais il possède d'importantes limitations, comme son support limité des fonctions de rappel (callbacks), ainsi qu'une gestion des erreurs archaïque, utilisation de handlers d'erreurs en lieu et place d'un mécanisme d'exceptions.
Même si ces limitations rendent ce langage très peu utilisé par les développeurs informaticiens soucieux d'utiliser des outils avant tout performants, sa simplicité et sa facilité d'accès ont séduit certaines professions, notamment dans la finance.
Obsolescence
Depuis le , Microsoft ne distribue plus de licences VBA à ses nouveaux clients[1] car ils essayent de les remplacer par Visual Studio Tools for Applications[2] (VSTA), un toolkit de customisation d'application basé sur la plateforme Framework .NET. De l'article de Dr eX[3] :
« Les éditeurs de logiciel utiliseront à présent VSTA en remplacement de VSA [Visual Studio for Applications], pour fournir des fonctionnalités de personnalisation dans leurs applications. […] VSA était un client léger, alternative de VBA gérée par un serveur, basé sur Visual Studio. L'approche serveur a été vue par les éditeurs comme moins utile qu'un modèle de client riche, donc, en se basant sur ce retour, Microsoft a commencé le développement de VSTA. Certains éditeurs utilisent toujours VSA aujourd'hui, mais nous trouvons son intérêt limité. Certaines des technologies développées pour VSA sont reprises dans VSTA. La personnalisation des applications à l'aide de VSTA tire un meilleur profit des fonctionnalités du client riche que VSA, offrant un environnement hautement optimisé pour la personnalisation d'applications à la fois côté client et côté serveur. »
« (en) VSTA now replaces VSA [Visual Studio for Applications] as the technology ISVs will use to provide customization capabilities in their applications. […] VSA was a thin-client, server-driven alternative to VBA built on Visual Studio. The server approach was viewed by ISVs as less useful than a rich-client model, so based on their feedback, Microsoft began development of VSTA. There are ISVs successfully using VSA today, but we found that its applicability was limited. Some of the technology developed for VSA is incorporated within VSTA. VSTA application customization takes better advantage of rich client functionality than VSA, offering a highly optimized environment for application customization on both the client and the server. »
Office 2007 continue à utiliser l'ancien moteur VBA ; cependant, Visual Studio Tools for Office (en) (VSTO) est disponible. La prise en charge de VBA dans Microsoft Office pour Mac a été abandonnée avec la distribution de la version 12, en 2008[4] puis réintroduit dans la version 2011[5]. Voir aussi VB.NET.
La première version de VSTA a été fournie en et a été intégrée dans différents ISV, y compris InfoPath 2007 et ABB Robotics. La prochaine version de VSTA (basée sur Visual Studio 2008 connu sous le nom de « Orcas ») sera distribuée vers . La seconde version de VSTA est très différente de la première, avec des fonctionnalités comme la programmation dynamique et la compatibilité WPF, WCF, WF, LINQ, et .NET 3.5.
Toutefois, en raison de la dépendance de certaines entreprises à VBA, VBA est encore disponible dans Office 2007, 2010, 2013 et 2016[6] - [7] et 2019. La dernière version 7.1 est incluse dans Office 2013. Le langage de macro Excel 4, antérieur à VBA, est lui aussi pris en charge, même par les dernières version d'Excel[8].
Historique
La popularité incroyable de Visual Basic après son lancement amena Microsoft à inclure une version simplifiée dans ses applications de bureautique afin de remplacer les différents langages de macro. Cependant, comme le démontre la chronologie, ce changement s’est fait sur une longue période[9].
- 1993 - Lancement de VBA avec Microsoft Excel (version 5)
- 1994 - Inclusion de VBA avec Microsoft Project
- 1995 - Inclusion de VBA avec Microsoft Access, remplaçant Access Basic
- 1996 - Inclusion de VBA dans Microsoft Word, remplaçant Word Basic
- 1997 - Lancement de VBA 5.0, couvrant la suite Microsoft Office 97
- 1997 - Microsoft permet l'utilisation de VBA pour d'autres applications
- 1998 - Lancement de VBA 6.0
- 2001 - Lancement de VBA 6.1 visible dans MS Office 2007
- 2010 - Lancement de VBA 7.0 (pour garantir la compatibilité des versions 32-bit et 64-bit de Microsoft Office)
- 2013 - Lancement de VBA 7.1 couvrant la suite office 2013, 2016 et 2019
Interopérabilité
Une prise en charge minimale de VBA est également disponible dans OpenOffice.org, à partir de la version 3.0[10].
Applications
Dans Excel
L'enregistreur de macros sous Microsoft Excel (Onglet Développeur / Enregistrer une Macro) permet de générer facilement du code VBA dans une procédure.
Toute la séquence d'action effectuée entre le début et la fin de l'enregistrement est enregistrée dans une procédure VBA, qui pourra être réexécutée à l'identique. Il est possible de modifier ce code ou de programmer directement dans la VBE (Onglet Développeur / Visual Basic).
C'est la meilleure méthode pour apprendre à se servir de VBA pour les programmeurs néophytes.
Tout d'abord, on enregistre une séquence en appuyant sur le bouton d'enregistrement, et ensuite on peut l'exécuter pas à pas (touche F8) dans l'outil VBA afin de savoir les actions effectuées par chaque ligne de code.
Les principales collections d'objets du tableur Excel sont WorkBook (classeur), Sheets (feuille de calcul) et Range (plage de cellules). Elles sont utilisables selon une hiérarchie descendante :
- Workbooks("Année 2012").Sheets("Mars").Range("B2") désigne la cellule B2 de la feuille Mars du classeur Année 2012 ;
- Sheets("Mars").Range("B2") du classeur actif (ouvert et affiché) ;
- Range("B2") de la feuille active.
Une fois un objet désigné :
- une méthode peut lui être appliquée (NomObjet.NomMéthode) : Range("B2").Select sélectionne la cellule B2…
- ses propriétés (NomObjet.Propriété) peuvent être consultées ou modifiées (affection NomObjet.Propriété=valeur) ; des propriétés courantes sont visibles (à utiliser avec True et False pour afficher ou masquer), Value (valeur d'une cellule), Count (nombre de cellules d'une page, de feuilles de classeur…).
Les références aux cellules peuvent être :
- absolues : Range("B2") ou Cells(2,2) désignent la cellule B2 de la feuille active ;
- relatives à la cellule d'origine : ActiveCell.Offset (2,-1) désigne la cellule située 2 lignes plus bas (- pour plus haut) et une colonne à gauche (+ pour à droite) de la cellule active.
Microsoft Excel permet de créer des fonctions personnalisées programmées en code VBA et placées dans un module. Elles sont ensuite accessibles dans la bibliothèque de fonction (Insertion / Fonction / Personnalisée) :
Function NomFonction (Argument1, Argument2 As TypeDonnées, Optional Argument3=valeur_defaut)
…(actions programmées)
NomFonction = valeur renvoyée
End Function
Ces fonctions peuvent recevoir des arguments en entrée, dont le type peut être spécifié (Argument2 ci-dessus) ou qui peuvent être optionnels, avec une valeur par défaut (Argument3 ci-dessus). Là encore, la procédure VBA permet d'automatiser tout type de tâche sous Microsoft Excel, avec comme conséquence un gain de temps et de confort d'utilisation[11].
Dans Word
Comme pour Excel, l'enregistreur de macro sous Microsoft Word (Onglet Développement / Nouvelle Macro) permet de générer facilement du code VBA dans une procédure.
Toute la séquence d'action effectuée entre le début et la fin de l'enregistrement est enregistrée dans une procédure VBA, qui pourra être réexécutée à l'identique. Il est possible de modifier ce code ou de programmer directement dans la VBE (Onglet Développement / Visual Basic Editor). L'enregistreur de macro est la meilleure méthode pour l'apprentissage VBA pour les programmeurs néophytes. Tout d'abord on enregistre une séquence en appuyant sur le bouton d'enregistrement, et ensuite on peut l'exécuter pas à pas (touche F8) dans l'outil VBA afin de vérifier les actions effectués par chaque ligne de code.
Les principales collections d'objets du traitement de texte Word sont Documents (les documents), BookMarks (les signets du document), Range (le contenu des signets). Elles sont utilisables selon une hiérarchie descendante :
- Documents("monDocument") le document choisi de l'ensemble des documents ouverts
- BookMarks("monSignet") un signet du document actif
- BookMarks("monSignet").Range.Text le texte attaché au signet du document actif
Une fois un objet désigné :
- une méthode peut lui être appliquée (NomObjet.NomMéthode) : ActiveDocument.SaveAs "monfichier.docx" enregistre le fichier WORD sous WINDOWS sous le nom monfichier.docx…
- ses propriétés (NomObjet.Propriété) peuvent être consultées ou modifiées (affection NomObjet.Propriété=valeur) ; des propriétés courantes sont Visible (à utiliser avec True et False pour afficher ou masquer), Text(contenu de paragraphe, de signet ou de sélection), Count (nombre d'objets d'une collection…).
Syntaxe
Condition
If i = 5 Then
MsgBox "Hello World!"
End If
Si i = 5 alors
Afficher "Hello World!"
Fin Si
For
For i = 1 To 5
j = 2 * j + 1-2*3
Next
Pour i allant de 1 à 5 avec un pas de 1
Multiplier j par 2 puis lui additionner 1 et enfin lui soustraire 2 multiplié par 3
Fin pour
Do Until
Do Until i = 5
i = i + 1
Loop
Jusqu'à ce que i = 5
Augmenter i de 1
Fin jusqu'à ce que
Do While
Do While i < 5
i = 2 * i + 1
Loop
Tant que i est inférieur à 5
Multiplier i par 2 et lui additionner 1
Fin tant que
Couleurs (sur Excel)
Range("A1").Interior.Color = RGB(255,0,0)
Colorer le fond de la cellule A1 en rouge
Range("A1").Font.Color = RGB(255,0,0)
Colorer le texte de la cellule A1 en rouge
Liens externes
Références
- (en) « VBA Language Specification ».
- http://msdn2.microsoft.com/en-us/vstudio/aa700828.aspx
- (en) « Howdy! What's up with VSA? », Dr. eX's Blog, 3 octobre 2005.
- (en) « WWDC: Microsoft updates Universal status of Mac apps », Macworld, (consulté le ).
- Pierre Dandumont, « Office 2011 : le 26 octobre, avec le VBA et Outlook », Tom's Hardware FR, 29 septembre 2010.
- « Office Dev Center - VBA improvements in Office 2016 », sur dev.office.com (consulté le )
- Michel Dumais, « Antidote, Office 2008, le «SP1» et le retour de «VBA» »(Archive.org • Wikiwix • Archive.is • Google • Que faire ?), sur mac.branchez-vous.com, .
- Working with Excel 4.0 macros
- Paul Lomax, VB & VBA in a Nutshell, O'Reilly & Associates Inc, 1998, p. 635 (ISBN 1-56592-358-8), p. 6.
- « OpenOffice.org 3.0 disponible en version Beta », generation-nt.com, 17 mai 2008.
- « Macro ? Vous avez dit Macro ? », sur Finance 3.1, (consulté le )