VBA - Guide rapide

VBA signifie Visual Basic pour Applications est un langage de programmation basé sur les événements de Microsoft qui est maintenant principalement utilisé avec les applications Microsoft Office telles que MSExcel, MS-Word et MS-Access.

Il aide les techniciens à créer des applications et des solutions personnalisées pour améliorer les capacités de ces applications. L'avantage de cette fonctionnalité est que vous N'AVEZ PAS BESOIN d'avoir visual basic installé sur notre PC, cependant, l'installation d'Office aidera implicitement à atteindre l'objectif.

Vous pouvez utiliser VBA dans toutes les versions de bureau, directement de MS-Office 97 à MS-Office 2013 et également avec l'une des dernières versions disponibles. Parmi VBA, Excel VBA est le plus populaire. L'avantage d'utiliser VBA est que vous pouvez créer des outils très puissants dans MS Excel en utilisant la programmation linéaire.

Application de VBA

Vous vous demandez peut-être pourquoi utiliser VBA dans Excel, car MS-Excel lui-même fournit de nombreuses fonctions intégrées. MS-Excel ne fournit que des fonctions intégrées de base qui peuvent ne pas être suffisantes pour effectuer des calculs complexes. Dans de telles circonstances, VBA devient la solution la plus évidente.

Par exemple, il est très difficile de calculer le remboursement mensuel d'un prêt à l'aide des formules intégrées d'Excel. Au contraire, il est facile de programmer un VBA pour un tel calcul.

Accéder à l'éditeur VBA

Dans la fenêtre Excel, appuyez sur "ALT + F11". Une fenêtre VBA s'ouvre comme indiqué dans la capture d'écran suivante.

Dans ce chapitre, vous apprendrez à écrire une macro simple étape par étape.

Step 1- Tout d'abord, activez le menu 'Développeur' dans Excel 20XX. Pour faire de même, cliquez sur Fichier → Options.

Step 2- Cliquez sur l'onglet «Personnaliser le ruban» et cochez «Développeur». Cliquez sur OK'.

Step 3 - Le ruban «Développeur» apparaît dans la barre de menus.

Step 4 - Cliquez sur le bouton 'Visual Basic' pour ouvrir l'éditeur VBA.

Step 5- Démarrez le script en ajoutant un bouton. Cliquez sur Insérer → Sélectionnez le bouton.

Step 6 - Effectuez un clic droit et choisissez «propriétés».

Step 7 - Modifiez le nom et la légende comme indiqué dans la capture d'écran suivante.

Step 8 - Maintenant, double-cliquez sur le bouton et le contour de la sous-procédure sera affiché comme indiqué dans la capture d'écran suivante.

Step 9 - Commencez à coder en ajoutant simplement un message.

Private Sub say_helloworld_Click()
   MsgBox "Hi"
End Sub

Step 10- Cliquez sur le bouton pour exécuter la sous-procédure. La sortie de la sous-procédure est présentée dans la capture d'écran suivante. Assurez-vous que le mode Création est activé. Cliquez simplement dessus pour l'activer s'il ne l'est pas.

Note - Dans d'autres chapitres, nous démontrerons en utilisant un simple bouton, comme expliqué de l'étape 1 à 10. Par conséquent, il est important de bien comprendre ce chapitre.

Dans ce chapitre, vous vous familiariserez avec les terminologies Excel VBA couramment utilisées. Ces terminologies seront utilisées dans d'autres modules, il est donc important de comprendre chacun d'entre eux.

Modules

Modules est la zone où le code est écrit. Il s'agit d'un nouveau classeur, il n'y a donc aucun module.

Pour insérer un module, accédez à Insérer → Module. Une fois qu'un module est inséré, «module1» est créé.

Dans les modules, nous pouvons écrire du code VBA et le code est écrit dans une procédure. Une procédure / sous-procédure est une série d'instructions VBA indiquant ce qu'il faut faire.

Procédure

Les procédures sont un groupe d'instructions exécutées dans leur ensemble, qui indique à Excel comment effectuer une tâche spécifique. La tâche effectuée peut être une tâche très simple ou très compliquée. Cependant, il est recommandé de décomposer les procédures compliquées en procédures plus petites.

Les deux principaux types de procédures sont Sub et Function.

Fonction

Une fonction est un groupe de code réutilisable, qui peut être appelé n'importe où dans votre programme. Cela élimine le besoin d'écrire le même code encore et encore. Cela aide les programmeurs à diviser un grand programme en un certain nombre de fonctions petites et gérables.

Outre les fonctions intégrées, VBA permet également d'écrire des fonctions définies par l'utilisateur et les instructions sont écrites entre Function et End Function.

Sous-procédures

Les sous-procédures fonctionnent de manière similaire aux fonctions. Alors que les sous-procédures NE renvoient PAS de valeur, les fonctions peuvent ou non renvoyer une valeur. Les sous-procédures PEUVENT être appelées sans mot-clé d'appel. Les sous-procédures sont toujours incluses dansSub et End Sub déclarations.

Les commentaires sont utilisés pour documenter la logique du programme et les informations utilisateur avec lesquelles d'autres programmeurs peuvent travailler de manière transparente sur le même code à l'avenir.

Il comprend des informations telles que développées par, modifiées par et peut également inclure une logique incorporée. Les commentaires sont ignorés par l'interpréteur lors de l'exécution.

Les commentaires dans VBA sont indiqués par deux méthodes.

  • Toute instruction commençant par un guillemet simple (') est traitée comme un commentaire. Voici un exemple.

' This Script is invoked after successful login 
' Written by : TutorialsPoint 
' Return Value : True / False
  • Toute instruction commençant par le mot-clé "REM". Voici un exemple.

REM This Script is written to Validate the Entered Input 
REM Modified by  : Tutorials point/user2

le MsgBox function affiche une boîte de message et attend que l'utilisateur clique sur un bouton, puis une action est effectuée en fonction du bouton cliqué par l'utilisateur.

Syntaxe

MsgBox(prompt[,buttons][,title][,helpfile,context])

Description des paramètres

  • Prompt- Un paramètre obligatoire. Une chaîne qui s'affiche sous forme de message dans la boîte de dialogue. La longueur maximale de l'invite est d'environ 1024 caractères. Si le message s'étend sur plus d'une ligne, les lignes peuvent être séparées à l'aide d'un caractère de retour chariot (Chr (13)) ou d'un caractère de saut de ligne (Chr (10)) entre chaque ligne.

  • Buttons- Un paramètre facultatif. Expression numérique qui spécifie le type de boutons à afficher, le style d'icône à utiliser, l'identité du bouton par défaut et la modalité de la boîte de message. Si ce champ est laissé vide, la valeur par défaut des boutons est 0.

  • Title- Un paramètre facultatif. Une expression String affichée dans la barre de titre de la boîte de dialogue. Si le titre est laissé vide, le nom de l'application est placé dans la barre de titre.

  • Helpfile- Un paramètre facultatif. Expression String qui identifie le fichier d'aide à utiliser pour fournir une aide contextuelle pour la boîte de dialogue.

  • Context- Un paramètre facultatif. Expression numérique qui identifie le numéro de contexte de l'aide attribué par l'auteur de l'aide à la rubrique d'aide appropriée. Si le contexte est fourni, le fichier d'aide doit également être fourni.

le Buttons paramètre peut prendre l'une des valeurs suivantes -

  • 0 vbOKOnly - Affiche uniquement le bouton OK.

  • 1 vbOKCancel - Affiche les boutons OK et Annuler.

  • 2 vbAbortRetryIgnore - Affiche les boutons Abandonner, Réessayer et Ignorer.

  • 3 vbYesNoCancel - Affiche les boutons Oui, Non et Annuler.

  • 4 vbYesNo - Affiche les boutons Oui et Non.

  • 5 vbRetryCancel - Affiche les boutons Réessayer et Annuler.

  • 16 vbCritical - Affiche l'icône de message critique.

  • 32 vbQuestion - Affiche l'icône de requête d'avertissement.

  • 48 vbExclamation - Affiche l'icône de message d'avertissement.

  • 64 vbInformation - Affiche l'icône de message d'information.

  • 0 vbDefaultButton1 - Le premier bouton est la valeur par défaut.

  • 256 vbDefaultButton2 - Le deuxième bouton est la valeur par défaut.

  • 512 vbDefaultButton3 - Le troisième bouton est la valeur par défaut.

  • 768 vbDefaultButton4 - Le quatrième bouton est la valeur par défaut.

  • 0 vbApplicationModal Application modal - L'application actuelle ne fonctionnera pas tant que l'utilisateur n'aura pas répondu à la boîte de message.

  • 4096 vbSystemModal System modal - Toutes les applications ne fonctionneront pas tant que l'utilisateur n'aura pas répondu à la boîte de message.

Les valeurs ci-dessus sont logiquement divisées en quatre groupes: first group(0 à 5) indique les boutons à afficher dans la boîte de message. lesecond group (16, 32, 48, 64) décrit le style de l'icône à afficher, le third group (0, 256, 512, 768) indique quel bouton doit être le bouton par défaut et le fourth group (0, 4096) détermine la modalité de la boîte de message.

Valeurs de retour

La fonction MsgBox peut renvoyer l'une des valeurs suivantes qui peuvent être utilisées pour identifier le bouton sur lequel l'utilisateur a cliqué dans la boîte de message.

  • 1 - vbOK - OK a été cliqué
  • 2 - vbCancel - Annuler a été cliqué
  • 3 - vbAbort - Abandon a été cliqué
  • 4 - vbRetry - Une nouvelle tentative a été cliquée
  • 5 - vbIgnore - Ignorer a été cliqué
  • 6 - vbYes - Oui a été cliqué
  • 7 - vbNo - Non a été cliqué

Exemple

Function MessageBox_Demo() 
   'Message Box with just prompt message 
   MsgBox("Welcome")     
   
   'Message Box with title, yes no and cancel Butttons  
   int a = MsgBox("Do you like blue color?",3,"Choose options") 
   ' Assume that you press No Button  
   msgbox ("The Value of a is " & a) 
End Function

Production

Step 1 - La fonction ci-dessus peut être exécutée en cliquant sur le bouton "Exécuter" de la fenêtre VBA ou en appelant la fonction à partir de la feuille de calcul Excel comme indiqué dans la capture d'écran suivante.

Step 2 - Une boîte de message simple s'affiche avec un message "Bienvenue" et un bouton "OK"

Step 3 - Après avoir cliqué sur OK, une autre boîte de dialogue s'affiche avec un message ainsi que des boutons «oui, non et annuler».

Step 4- Après avoir cliqué sur le bouton «Non», la valeur de ce bouton (7) est stockée sous forme d'entier et affichée sous forme de boîte de message à l'utilisateur, comme illustré dans la capture d'écran suivante. En utilisant cette valeur, on peut comprendre sur quel bouton l'utilisateur a cliqué.

le InputBox functioninvite les utilisateurs à entrer des valeurs. Après avoir entré les valeurs, si l'utilisateur clique sur le bouton OK ou appuie sur ENTRÉE sur le clavier, la fonction InputBox renverra le texte dans la zone de texte. Si l'utilisateur clique sur le bouton Annuler, la fonction renverra une chaîne vide ("").

Syntaxe

InputBox(prompt[,title][,default][,xpos][,ypos][,helpfile,context])

Description des paramètres

  • Prompt- Un paramètre obligatoire. Une chaîne qui s'affiche sous forme de message dans la boîte de dialogue. La longueur maximale de l'invite est d'environ 1024 caractères. Si le message s'étend sur plus d'une ligne, les lignes peuvent être séparées à l'aide d'un caractère de retour chariot (Chr (13)) ou d'un caractère de saut de ligne (Chr (10)) entre chaque ligne.

  • Title- Un paramètre facultatif. Une expression String affichée dans la barre de titre de la boîte de dialogue. Si le titre est laissé vide, le nom de l'application est placé dans la barre de titre.

  • Default- Un paramètre facultatif. Un texte par défaut dans la zone de texte que l'utilisateur souhaite afficher.

  • XPos- Un paramètre facultatif. La position deXL'axe représente la distance de l'invite du côté gauche de l'écran horizontalement. Si elle est laissée vide, la zone de saisie est centrée horizontalement.

  • YPos- Un paramètre facultatif. La position deYL'axe représente la distance d'invite du côté gauche de l'écran verticalement. Si elle est laissée vide, la zone de saisie est centrée verticalement.

  • Helpfile- Un paramètre facultatif. Expression String qui identifie le fichier d'aide à utiliser pour fournir une aide contextuelle pour la boîte de dialogue.

  • context- Un paramètre facultatif. Expression numérique qui identifie le numéro de contexte de l'aide attribué par l'auteur de l'aide à la rubrique d'aide appropriée. Si le contexte est fourni, le fichier d'aide doit également être fourni.

Exemple

Calculons l'aire d'un rectangle en obtenant les valeurs de l'utilisateur au moment de l'exécution à l'aide de deux zones de saisie (une pour la longueur et une pour la largeur).

Function findArea() 
   Dim Length As Double 
   Dim Width As Double 
   
   Length = InputBox("Enter Length ", "Enter a Number") 
   Width = InputBox("Enter Width", "Enter a Number") 
   findArea = Length * Width 
End Function

Production

Step 1 - Pour exécuter la même chose, appelez en utilisant le nom de la fonction et appuyez sur Entrée comme indiqué dans la capture d'écran suivante.

Step 2- Lors de l'exécution, la première zone de saisie (longueur) s'affiche. Entrez une valeur dans la zone de saisie.

Step 3 - Après avoir entré la première valeur, la deuxième zone de saisie (largeur) s'affiche.

Step 4- Lors de la saisie du deuxième numéro, cliquez sur le bouton OK. La zone est affichée comme illustré dans la capture d'écran suivante.

Variableest un emplacement mémoire nommé utilisé pour contenir une valeur qui peut être modifiée lors de l'exécution du script. Voici les règles de base pour nommer une variable.

  • Vous devez utiliser une lettre comme premier caractère.

  • Vous ne pouvez pas utiliser d'espace, point (.), Point d'exclamation (!) Ou les caractères @, &, $, # dans le nom.

  • Le nom ne peut pas dépasser 255 caractères.

  • Vous ne pouvez pas utiliser de mots clés réservés Visual Basic comme nom de variable.

Syntax

Dans VBA, vous devez déclarer les variables avant de les utiliser.

Dim <<variable_name>> As <<variable_type>>

Types de données

Il existe de nombreux types de données VBA, qui peuvent être divisés en deux catégories principales, à savoir les types de données numériques et non numériques.

Types de données numériques

Le tableau suivant affiche les types de données numériques et la plage de valeurs autorisée.

Type Gamme de valeurs
Octet 0 à 255
Entier -32 768 à 32 767
Longue -2 147 483 648 à 2 147 483 648
Célibataire

-3.402823E + 38 à -1.401298E-45 pour les valeurs négatives

1.401298E-45 à 3.402823E + 38 pour les valeurs positives.

Double

-1,79769313486232e + 308 à -4,94065645841247E-324 pour les valeurs négatives

4.94065645841247E-324 à 1.79769313486232e + 308 pour les valeurs positives.

Devise -922.337.203.685.477.5808 à 922.337.203.685.477.5807
Décimal

+/- 79,228,162,514,264,337,593,543,950,335 si aucune décimale n'est utilisée

+/- 7,9228162514264337593543950335 (28 décimales).

Types de données non numériques

Le tableau suivant affiche les types de données non numériques et la plage de valeurs autorisée.

Type Gamme de valeurs
Chaîne (longueur fixe) 1 à 65400 caractères
Chaîne (longueur variable) 0 à 2 milliards de caractères
Date 1 janvier 100 au 31 décembre 9999
Booléen Vrai ou faux
Objet Tout objet incorporé
Variante (numérique) Toute valeur aussi grande que le double
Variante (texte) Identique à la chaîne de longueur variable

Example

Créons un bouton et appelons-le «Variables_demo» pour illustrer l'utilisation des variables.

Private Sub say_helloworld_Click()
   Dim password As String
   password = "Admin#1"

   Dim num As Integer
   num = 1234

   Dim BirthDay As Date
   BirthDay = DateValue("30 / 10 / 2020")

   MsgBox "Passowrd is " & password & Chr(10) & "Value of num is " &
      num & Chr(10) & "Value of Birthday is " & BirthDay
End Sub

Output

Lors de l'exécution du script, la sortie sera comme indiqué dans la capture d'écran suivante.

La constante est un emplacement mémoire nommé utilisé pour contenir une valeur qui NE PEUT PAS être modifiée pendant l'exécution du script. Si un utilisateur tente de modifier une valeur constante, l'exécution du script se termine par une erreur. Les constantes sont déclarées de la même manière que les variables.

Voici les règles pour nommer une constante.

  • Vous devez utiliser une lettre comme premier caractère.

  • Vous ne pouvez pas utiliser d'espace, point (.), Point d'exclamation (!) Ou les caractères @, &, $, # dans le nom.

  • Le nom ne peut pas dépasser 255 caractères.

  • Vous ne pouvez pas utiliser de mots clés réservés Visual Basic comme nom de variable.

Syntaxe

Dans VBA, nous devons attribuer une valeur aux constantes déclarées. Une erreur est générée si nous essayons de changer la valeur de la constante.

Const <<constant_name>> As <<constant_type>> = <<constant_value>>

Exemple

Créons un bouton "Constant_demo" pour montrer comment travailler avec des constantes.

Private Sub Constant_demo_Click() 
   Const MyInteger As Integer = 42 
   Const myDate As Date = #2/2/2020# 
   Const myDay As String = "Sunday" 
   
   MsgBox "Integer is " & MyInteger & Chr(10) & "myDate is " 
      & myDate & Chr(10) & "myDay is " & myDay  
End Sub

Production

Lors de l'exécution du script, la sortie sera affichée comme indiqué dans la capture d'écran suivante.

Un Operator peut être défini à l'aide d'une expression simple - 4 + 5 est égal à 9. Ici, 4 et 5 sont appelés operands et + est appelé operator. VBA prend en charge les types d'opérateurs suivants -

  • Opérateurs arithmétiques
  • Opérateurs de comparaison
  • Opérateurs logiques (ou relationnels)
  • Opérateurs de concaténation

Les opérateurs arithmatiques

Les opérateurs arithmétiques suivants sont pris en charge par VBA.

Supposons que la variable A vaut 5 et la variable B vaut 10, alors -

Afficher des exemples

Opérateur La description Exemple
+ Ajoute les deux opérandes A + B donnera 15
- Soustrait le deuxième opérande du premier A - B donnera -5
* Multiplie les deux opérandes A * B donnera 50
/ Divise le numérateur par le dénominateur B / A donnera 2
% Opérateur de module et le reste après une division entière B% A donnera 0
^ Opérateur d'exponentiation B ^ A donnera 100000

Les opérateurs de comparaison

Les opérateurs de comparaison suivants sont pris en charge par VBA.

Supposons que la variable A vaut 10 et la variable B 20, alors -

Afficher des exemples

Opérateur La description Exemple
= Vérifie si la valeur des deux opérandes est égale ou non. Si oui, alors la condition est vraie. (A = B) est faux.
<> Vérifie si la valeur des deux opérandes est égale ou non. Si les valeurs ne sont pas égales, la condition est vraie. (A <> B) est vrai.
> Vérifie si la valeur de l'opérande gauche est supérieure à la valeur de l'opérande droit. Si oui, alors la condition est vraie. (A> B) est faux.
< Vérifie si la valeur de l'opérande gauche est inférieure à la valeur de l'opérande droit. Si oui, alors la condition est vraie. (A <B) est vrai.
> = Vérifie si la valeur de l'opérande gauche est supérieure ou égale à la valeur de l'opérande droit. Si oui, alors la condition est vraie. (A> = B) est faux.
<= Vérifie si la valeur de l'opérande gauche est inférieure ou égale à la valeur de l'opérande droit. Si oui, alors la condition est vraie. (A <= B) est vrai.

Les opérateurs logiques

Les opérateurs logiques suivants sont pris en charge par VBA.

Supposons que la variable A vaut 10 et la variable B vaut 0, alors -

Afficher des exemples

Opérateur La description Exemple
ET Opérateur logique ET appelé. Si les deux conditions sont vraies, alors l'expression est vraie. a <> 0 ET b <> 0 est faux.
OU Opérateur OU logique appelé. Si l'une des deux conditions est vraie, la condition est vraie. a <> 0 OU b <> 0 est vrai.
NE PAS Opérateur PAS logique appelé. Utilisé pour inverser l'état logique de son opérande. Si une condition est vraie, alors l'opérateur logique NOT rendra faux. NOT (a <> 0 OU b <> 0) est faux.
XOR Exclusion logique appelée. C'est la combinaison de l'opérateur NOT et OR. Si une et une seule des expressions est évaluée à True, le résultat est True. (a <> 0 XOR b <> 0) est vrai.

Les opérateurs de concaténation

Les opérateurs de concaténation suivants sont pris en charge par VBA.

Supposons que la variable A vaut 5 et la variable B vaut 10 alors -

Afficher des exemples

Opérateur La description Exemple
+ Ajoute deux valeurs comme variable. Les valeurs sont numériques A + B donnera 15
& Concatène deux valeurs A & B donnera 510

Supposons que la variable A = "Microsoft" et la variable B = "VBScript", alors -

Opérateur La description Exemple
+ Concatène deux valeurs A + B donnera MicrosoftVBScript
& Concatène deux valeurs A & B donnera MicrosoftVBScript

Note- Les opérateurs de concaténation peuvent être utilisés pour les nombres et les chaînes. La sortie dépend du contexte, si les variables contiennent une valeur numérique ou une valeur de chaîne.

La prise de décision permet aux programmeurs de contrôler le flux d'exécution d'un script ou de l'une de ses sections. L'exécution est régie par une ou plusieurs instructions conditionnelles.

Voici la forme générale d'une structure de prise de décision typique trouvée dans la plupart des langages de programmation.

VBA fournit les types suivants d'énoncés de prise de décision. Cliquez sur les liens suivants pour vérifier leurs détails.

Sr.No. Déclaration et description
1 si déclaration

Un if instruction se compose d'une expression booléenne suivie d'une ou plusieurs instructions.

2 instruction if..else

Un if elseinstruction se compose d'une expression booléenne suivie d'une ou plusieurs instructions. Si la condition est True, les instructions sousIfles instructions sont exécutées. Si la condition est fausse, leElse une partie du script est exécutée.

3 instruction if ... elseif..else

Un if instruction suivie d'un ou plusieurs ElseIf instructions, qui se composent d'expressions booléennes, puis suivies d'une option else statement, qui s'exécute lorsque toutes les conditions deviennent fausses.

4 instructions if imbriquées

Un if ou elseif déclaration dans un autre if ou elseif déclaration (s).

5 instruction switch

UNE switch L'instruction permet à une variable d'être testée pour l'égalité par rapport à une liste de valeurs.

Il peut arriver que vous deviez exécuter un bloc de code plusieurs fois. En général, les instructions sont exécutées de manière séquentielle: la première instruction d'une fonction est exécutée en premier, suivie de la seconde, et ainsi de suite.

Les langages de programmation fournissent diverses structures de contrôle qui permettent des chemins d'exécution plus compliqués.

Une instruction de boucle nous permet d'exécuter une instruction ou un groupe d'instructions plusieurs fois. Voici la forme générale d'une instruction de boucle dans VBA.

VBA fournit les types de boucles suivants pour gérer les exigences de bouclage. Cliquez sur les liens suivants pour vérifier leurs détails.

Sr.No. Type de boucle et description
1 pour boucle

Exécute une séquence d'instructions plusieurs fois et abrége le code qui gère la variable de boucle.

2 pour ..chaque boucle

Ceci est exécuté s'il y a au moins un élément dans le groupe et réitéré pour chaque élément d'un groupe.

3 boucle while..wend

Cela teste la condition avant d'exécuter le corps de la boucle.

4 boucles do.. while

Les instructions do..While seront exécutées tant que la condition est vraie (c'est-à-dire) La boucle doit être répétée jusqu'à ce que la condition soit False.

5 faire..jusqu'à des boucles

Les instructions do..Until seront exécutées tant que la condition est False (c'est-à-dire) La boucle doit être répétée jusqu'à ce que la condition soit True.

Déclarations de contrôle de boucle

Les instructions de contrôle de boucle modifient l'exécution de sa séquence normale. Lorsque l'exécution quitte une portée, toutes les instructions restantes dans la boucle ne sont PAS exécutées.

VBA prend en charge les instructions de contrôle suivantes. Cliquez sur les liens suivants pour vérifier leurs détails.

S.No. Déclaration de contrôle et description
1 Exit For instruction

Met fin au For loop instruction et transfère l'exécution à l'instruction immédiatement après la boucle

2 Instruction Exit Do

Met fin au Do While instruction et transfère l'exécution à l'instruction immédiatement après la boucle

Les chaînes sont une séquence de caractères, qui peut être constituée d'alphabets, de nombres, de caractères spéciaux ou de tous. Une variable est considérée comme une chaîne si elle est placée entre guillemets doubles "".

Syntaxe

variablename = "string"

Exemples

str1 = "string"   ' Only Alphabets
str2 = "132.45"   ' Only Numbers
str3 = "!@#$;*"  ' Only Special Characters
Str4 = "Asc23@#"  ' Has all the above

Fonctions de chaîne

Il existe des fonctions de chaîne VBA prédéfinies, qui aident les développeurs à travailler avec les chaînes de manière très efficace. Voici les méthodes String prises en charge dans VBA. Veuillez cliquer sur chacune des méthodes pour connaître en détail.

Sr.No. Nom et description de la fonction
1 InStr

Renvoie la première occurrence de la sous-chaîne spécifiée. La recherche s'effectue de la gauche vers la droite.

2 InstrRev

Renvoie la première occurrence de la sous-chaîne spécifiée. La recherche s'effectue de la droite vers la gauche.

3 Lcase

Renvoie les minuscules de la chaîne spécifiée.

4 Ucase

Renvoie les majuscules de la chaîne spécifiée.

5 La gauche

Renvoie un nombre spécifique de caractères du côté gauche de la chaîne.

6 Droite

Renvoie un nombre spécifique de caractères du côté droit de la chaîne.

sept Milieu

Renvoie un nombre spécifique de caractères d'une chaîne en fonction des paramètres spécifiés.

8 Ltrim

Renvoie une chaîne après avoir supprimé les espaces sur le côté gauche de la chaîne spécifiée.

9 Rtrim

Renvoie une chaîne après avoir supprimé les espaces sur le côté droit de la chaîne spécifiée.

dix Réduire

Renvoie une valeur de chaîne après avoir supprimé les espaces vides de début et de fin.

11 Len

Renvoie la longueur de la chaîne donnée.

12 Remplacer

Renvoie une chaîne après avoir remplacé une chaîne par une autre chaîne.

13 Espace

Remplit une chaîne avec le nombre d'espaces spécifié.

14 StrComp

Renvoie une valeur entière après avoir comparé les deux chaînes spécifiées.

15 Chaîne

Renvoie une chaîne avec un caractère spécifié pour un nombre de fois spécifié.

16 StrReverse

Renvoie une chaîne après avoir inversé la séquence des caractères de la chaîne donnée.

Les fonctions de date et d'heure de VBScript aident les développeurs à convertir la date et l'heure d'un format à un autre ou à exprimer la valeur de la date ou de l'heure dans le format qui convient à une condition spécifique.

Fonctions de date

Sr.No. Description de la fonction
1 Date

Une fonction, qui renvoie la date système actuelle.

2 CDate

Une fonction, qui convertit une entrée donnée en date.

3 DateAjouter

Une fonction, qui renvoie une date à laquelle un intervalle de temps spécifié a été ajouté.

4 DateDiff

Une fonction, qui renvoie la différence entre deux périodes.

5 DatePart

Une fonction, qui renvoie une partie spécifiée de la valeur de date d'entrée donnée.

6 DateSerial

Une fonction, qui renvoie une date valide pour l'année, le mois et la date donnés.

sept FormatDateTime

Une fonction, qui formate la date en fonction des paramètres fournis.

8 IsDate

Une fonction, qui renvoie une valeur booléenne, que le paramètre fourni soit ou non une date.

9 journée

Une fonction, qui renvoie un entier entre 1 et 31 qui représente le jour de la date spécifiée.

dix Mois

Une fonction, qui renvoie un entier entre 1 et 12 qui représente le mois de la date spécifiée.

11 An

Une fonction, qui renvoie un entier qui représente l'année de la date spécifiée.

12 MonthName

Une fonction, qui renvoie le nom du mois particulier pour la date spécifiée.

13 Jour de la semaine

Une fonction, qui renvoie un entier (1 à 7) qui représente le jour de la semaine pour le jour spécifié.

14 WeekDayName

Une fonction, qui renvoie le nom du jour de la semaine pour le jour spécifié.

Fonctions de temps

Sr.No. Description de la fonction
1 Maintenant

Une fonction, qui renvoie la date et l'heure actuelles du système.

2 Heure

Une fonction, qui renvoie un entier entre 0 et 23 qui représente la partie heure de l'heure donnée.

3 Minute

Une fonction, qui renvoie un entier entre 0 et 59 qui représente la partie minutes de l'heure donnée.

4 Seconde

Une fonction, qui renvoie un entier compris entre 0 et 59 qui représente la partie des secondes du temps donné.

5 Temps

Une fonction, qui renvoie l'heure système actuelle.

6 Minuteur

Une fonction, qui renvoie le nombre de secondes et de millisecondes depuis minuit.

sept TimeSerial

Une fonction, qui renvoie l'heure pour l'entrée spécifique d'heure, de minute et de seconde.

8 Valeur de temps

Une fonction, qui convertit la chaîne d'entrée en un format d'heure.

On sait très bien qu'une variable est un conteneur pour stocker une valeur. Parfois, les développeurs sont en mesure de conserver plusieurs valeurs dans une seule variable à la fois. Lorsqu'une série de valeurs est stockée dans une seule variable, on parle alors dearray variable.

Déclaration Array

Les tableaux sont déclarés de la même manière qu'une variable a été déclarée, sauf que la déclaration d'une variable de tableau utilise des parenthèses. Dans l'exemple suivant, la taille du tableau est mentionnée entre crochets.

'Method 1 : Using Dim
Dim arr1()	'Without Size

'Method 2 : Mentioning the Size
Dim arr2(5)  'Declared with size of 5

'Method 3 : using 'Array' Parameter
Dim arr3
arr3 = Array("apple","Orange","Grapes")
  • Bien que la taille du tableau soit indiquée comme 5, elle peut contenir 6 valeurs car l'index du tableau commence à zéro.

  • L'index du tableau ne peut pas être négatif.

  • Les tableaux VBScript peuvent stocker tout type de variable dans un tableau. Par conséquent, un tableau peut stocker un entier, une chaîne ou des caractères dans une seule variable de tableau.

Attribution de valeurs à un tableau

Les valeurs sont affectées au tableau en spécifiant une valeur d'index de tableau pour chacune des valeurs à attribuer. Cela peut être une chaîne.

Exemple

Ajoutez un bouton et ajoutez la fonction suivante.

Private Sub Constant_demo_Click()
   Dim arr(5)
   arr(0) = "1"           'Number as String
   arr(1) = "VBScript"    'String
   arr(2) = 100 		     'Number
   arr(3) = 2.45 		     'Decimal Number
   arr(4) = #10/07/2013#  'Date
   arr(5) = #12.45 PM#    'Time
  
   msgbox("Value stored in Array index 0 : " & arr(0))
   msgbox("Value stored in Array index 1 : " & arr(1))
   msgbox("Value stored in Array index 2 : " & arr(2))
   msgbox("Value stored in Array index 3 : " & arr(3))
   msgbox("Value stored in Array index 4 : " & arr(4))
   msgbox("Value stored in Array index 5 : " & arr(5))
End Sub

Lorsque vous exécutez la fonction ci-dessus, elle produit la sortie suivante.

Value stored in Array index 0 : 1
Value stored in Array index 1 : VBScript
Value stored in Array index 2 : 100
Value stored in Array index 3 : 2.45
Value stored in Array index 4 : 7/10/2013
Value stored in Array index 5 : 12:45:00 PM

Tableaux multidimensionnels

Les tableaux ne sont pas seulement limités à une seule dimension, cependant, ils peuvent avoir un maximum de 60 dimensions. Les tableaux bidimensionnels sont les plus couramment utilisés.

Exemple

Dans l'exemple suivant, un tableau multidimensionnel est déclaré avec 3 lignes et 4 colonnes.

Private Sub Constant_demo_Click()
   Dim arr(2,3) as Variant	' Which has 3 rows and 4 columns
   arr(0,0) = "Apple" 
   arr(0,1) = "Orange"
   arr(0,2) = "Grapes"           
   arr(0,3) = "pineapple" 
   arr(1,0) = "cucumber"           
   arr(1,1) = "beans"           
   arr(1,2) = "carrot"           
   arr(1,3) = "tomato"           
   arr(2,0) = "potato"             
   arr(2,1) = "sandwitch"            
   arr(2,2) = "coffee"             
   arr(2,3) = "nuts"            
           
   msgbox("Value in Array index 0,1 : " &  arr(0,1))
   msgbox("Value in Array index 2,2 : " &  arr(2,2))
End Sub

Lorsque vous exécutez la fonction ci-dessus, elle produit la sortie suivante.

Value stored in Array index : 0 , 1 : Orange
Value stored in Array index : 2 , 2 : coffee

Déclaration ReDim

L'instruction ReDim est utilisée pour déclarer des variables de tableau dynamique et allouer ou réallouer de l'espace de stockage.

Syntaxe

ReDim [Preserve] varname(subscripts) [, varname(subscripts)]

Description des paramètres

  • Preserve - Un paramètre facultatif utilisé pour conserver les données dans un tableau existant lorsque vous modifiez la taille de la dernière dimension.

  • Varname - Un paramètre obligatoire, qui indique le nom de la variable, qui doit suivre les conventions de dénomination de variable standard.

  • Subscripts - Un paramètre obligatoire, qui indique la taille du tableau.

Exemple

Dans l'exemple suivant, un tableau a été redéfini, puis les valeurs conservées lorsque la taille existante du tableau est modifiée.

Note - Lors du redimensionnement d'un tableau plus petit qu'il ne l'était à l'origine, les données des éléments éliminés seront perdues.

Private Sub Constant_demo_Click()
   Dim a() as variant
   i = 0
   redim a(5)
   a(0) = "XYZ"
   a(1) = 41.25
   a(2) = 22
  
   REDIM PRESERVE a(7)
   For i = 3 to 7
   a(i) = i
   Next
  
   'to Fetch the output
   For i = 0 to ubound(a)
      Msgbox a(i)
   Next
End Sub

Lorsque vous exécutez la fonction ci-dessus, elle produit la sortie suivante.

XYZ
41.25
22
3
4
5
6
7

Méthodes de tableau

Il existe diverses fonctions intégrées dans VBScript qui aident les développeurs à gérer efficacement les tableaux. Toutes les méthodes utilisées avec les tableaux sont répertoriées ci-dessous. Veuillez cliquer sur le nom de la méthode pour en savoir plus.

Sr.No. Description de la fonction
1 LBound

Une fonction, qui renvoie un entier correspondant au plus petit indice des tableaux donnés.

2 UBound

Une fonction, qui renvoie un entier correspondant au plus grand indice des tableaux donnés.

3 Divisé

Une fonction, qui renvoie un tableau contenant un nombre spécifié de valeurs. Fractionner basé sur un délimiteur.

4 Joindre

Une fonction, qui renvoie une chaîne qui contient un nombre spécifié de sous-chaînes dans un tableau. C'est une fonction exactement opposée à la méthode de fractionnement.

5 Filtre

Une fonction, qui renvoie un tableau de base zéro qui contient un sous-ensemble d'un tableau de chaînes basé sur un critère de filtre spécifique.

6 IsArray

Une fonction, qui renvoie une valeur booléenne indiquant si la variable d'entrée est ou non un tableau.

sept Effacer

Une fonction, qui récupère la mémoire allouée pour les variables du tableau.

UNE functionest un groupe de code réutilisable qui peut être appelé n'importe où dans votre programme. Cela élimine le besoin d'écrire le même code encore et encore. Cela permet aux programmeurs de diviser un grand programme en un certain nombre de fonctions petites et gérables.

Outre les fonctions intégrées, VBA permet également d'écrire des fonctions définies par l'utilisateur. Dans ce chapitre, vous apprendrez à écrire vos propres fonctions dans VBA.

Définition de fonction

Une fonction VBA peut avoir une instruction de retour facultative. Ceci est obligatoire si vous souhaitez renvoyer une valeur à partir d'une fonction.

Par exemple, vous pouvez passer deux nombres dans une fonction, puis vous pouvez vous attendre à ce que la fonction renvoie leur multiplication dans votre programme appelant.

Note - Une fonction peut renvoyer plusieurs valeurs séparées par une virgule sous la forme d'un tableau affecté au nom de la fonction lui-même.

Avant d'utiliser une fonction, nous devons définir cette fonction particulière. La manière la plus courante de définir une fonction dans VBA consiste à utiliser leFunction mot-clé, suivi d'un nom de fonction unique et il peut ou non porter une liste de paramètres et une instruction avec End Functionmot-clé, qui indique la fin de la fonction. Voici la syntaxe de base.

Syntaxe

Ajoutez un bouton et ajoutez la fonction suivante.

Function Functionname(parameter-list)
   statement 1
   statement 2
   statement 3
   .......
   statement n
End Function

Exemple

Ajoutez la fonction suivante qui renvoie la zone. Notez qu'une valeur / des valeurs peuvent être renvoyées avec le nom de la fonction lui-même.

Function findArea(Length As Double, Optional Width As Variant)
   If IsMissing(Width) Then
      findArea = Length * Length
   Else
      findArea = Length * Width
   End If
End Function

Appeler une fonction

Pour appeler une fonction, appelez la fonction en utilisant le nom de la fonction comme indiqué dans la capture d'écran suivante.

La sortie de la zone comme indiqué ci-dessous sera affichée à l'utilisateur.

Sub Procedures sont similaires aux fonctions, mais il existe quelques différences.

  • Les sous-procédures NE renvoient PAS de valeur alors que les fonctions peuvent ou non renvoyer une valeur.

  • Les sous-procédures PEUVENT être appelées sans mot clé d'appel.

  • Les procédures Sub sont toujours incluses dans les instructions Sub et End Sub.

Exemple

Sub Area(x As Double, y As Double)
   MsgBox x * y
End Sub

Procédures d'appel

Pour appeler une procédure quelque part dans le script, vous pouvez effectuer un appel à partir d'une fonction. Nous ne pourrons pas utiliser la même manière que celle d'une fonction car la sous-procédure NE retournera PAS de valeur.

Function findArea(Length As Double, Width As Variant)
   area Length, Width    ' To Calculate Area 'area' sub proc is called
End Function

Vous pourrez maintenant appeler la fonction uniquement mais pas la sous-procédure comme indiqué dans la capture d'écran suivante.

La zone est calculée et affichée uniquement dans la zone Message.

La cellule de résultat affiche ZERO car la valeur de la zone n'est PAS renvoyée par la fonction. En bref, vous ne pouvez pas appeler directement une sous-procédure à partir de la feuille de calcul Excel.

VBA, une programmation événementielle peut être déclenchée lorsque vous modifiez manuellement une cellule ou une plage de valeurs de cellule. L'événement de changement peut faciliter les choses, mais vous pouvez très rapidement terminer une page pleine de formatage. Il existe deux types d'événements.

  • Événements de la feuille de travail
  • Événements du classeur

Événements de la feuille de travail

Les événements de feuille de calcul sont déclenchés en cas de modification de la feuille de calcul. Il est créé en effectuant un clic droit sur l'onglet de la feuille et en choisissant «afficher le code», puis en collant le code.

L'utilisateur peut sélectionner chacune de ces feuilles de calcul et choisir «Feuille de travail» dans la liste déroulante pour obtenir la liste de tous les événements de feuille de travail pris en charge.

Voici les événements de feuille de calcul pris en charge qui peuvent être ajoutés par l'utilisateur.

Private Sub Worksheet_Activate() 
Private Sub Worksheet_BeforeDoubleClick(ByVal Target As Range, Cancel As Boolean)    
Private Sub Worksheet_BeforeRightClick(ByVal Target As Range, Cancel As Boolean) 
Private Sub Worksheet_Calculate() 
Private Sub Worksheet_Change(ByVal Target As Range) 
Private Sub Worksheet_Deactivate() 
Private Sub Worksheet_FollowHyperlink(ByVal Target As Hyperlink) 
Private Sub Worksheet_SelectionChange(ByVal Target As Range)

Exemple

Disons qu'il suffit d'afficher un message avant de double-cliquer.

Private Sub Worksheet_BeforeDoubleClick(ByVal Target As Range, Cancel As Boolean)
   MsgBox "Before Double Click"
End Sub

Production

Lors d'un double-clic sur une cellule, la boîte de message s'affiche à l'utilisateur comme indiqué dans la capture d'écran suivante.

Événements du classeur

Les événements de classeur sont déclenchés en cas de modification du classeur dans son ensemble. Nous pouvons ajouter le code pour les événements de classeur en sélectionnant `` Ce classeur '' et en sélectionnant `` classeur '' dans la liste déroulante, comme indiqué dans la capture d'écran suivante. Immédiatement, la sous-procédure Workbook_open est affichée à l'utilisateur, comme illustré dans la capture d'écran suivante.

Voici les événements de classeur pris en charge qui peuvent être ajoutés par l'utilisateur.

Private Sub Workbook_AddinUninstall() 
Private Sub Workbook_BeforeClose(Cancel As Boolean) 
Private Sub Workbook_BeforePrint(Cancel As Boolean) 
Private Sub Workbook_BeforeSave(ByVal SaveAsUI As Boolean, Cancel As Boolean) 
Private Sub Workbook_Deactivate() 
Private Sub Workbook_NewSheet(ByVal Sh As Object) 
Private Sub Workbook_Open() 
Private Sub Workbook_SheetActivate(ByVal Sh As Object) 
Private Sub Workbook_SheetBeforeDoubleClick(ByVal Sh As Object, ByVal Target As Range, Cancel As Boolean) 
Private Sub Workbook_SheetBeforeRightClick(ByVal Sh As Object, ByVal Target As Range, Cancel As Boolean) 
Private Sub Workbook_SheetCalculate(ByVal Sh As Object) 
Private Sub Workbook_SheetChange(ByVal Sh As Object, ByVal Target As Range) 
Private Sub Workbook_SheetDeactivate(ByVal Sh As Object) 
Private Sub Workbook_SheetFollowHyperlink(ByVal Sh As Object, ByVal Target As Hyperlink) 
Private Sub Workbook_SheetSelectionChange(ByVal Sh As Object, ByVal Target As Range) 
Private Sub Workbook_WindowActivate(ByVal Wn As Window) 
Private Sub Workbook_WindowDeactivate(ByVal Wn As Window) 
Private Sub Workbook_WindowResize(ByVal Wn As Window)

Exemple

Disons que nous avons juste besoin d'afficher un message à l'utilisateur indiquant qu'une nouvelle feuille est créée avec succès, chaque fois qu'une nouvelle feuille est créée.

Private Sub Workbook_NewSheet(ByVal Sh As Object)
   MsgBox "New Sheet Created Successfully"
End Sub

Production

Lors de la création d'une nouvelle feuille Excel, un message est affiché à l'utilisateur comme indiqué dans la capture d'écran suivante.

Il existe trois types d'erreurs de programmation: (a) les erreurs de syntaxe, (b) les erreurs d'exécution et (c) les erreurs logiques.

Erreurs de syntaxe

Les erreurs de syntaxe, également appelées erreurs d'analyse, se produisent au moment de l'interprétation de VBScript. Par exemple, la ligne suivante provoque une erreur de syntaxe car il manque une parenthèse fermante.

Function ErrorHanlding_Demo()
   dim x,y
   x = "Tutorialspoint"
   y = Ucase(x
End Function

Erreurs d'exécution

Les erreurs d'exécution, également appelées exceptions, se produisent pendant l'exécution, après interprétation.

Par exemple, la ligne suivante provoque une erreur d'exécution car ici la syntaxe est correcte, mais au moment de l'exécution, elle tente d'appeler fnmultiply, qui est une fonction non existante.

Function ErrorHanlding_Demo1()
   Dim x,y
   x = 10
   y = 20
   z = fnadd(x,y)
   a = fnmultiply(x,y)
End Function

Function fnadd(x,y)
   fnadd = x + y
End Function

Erreurs logiques

Les erreurs logiques peuvent être le type d'erreurs le plus difficile à localiser. Ces erreurs ne sont pas le résultat d'une erreur de syntaxe ou d'exécution. Au lieu de cela, ils se produisent lorsque vous faites une erreur dans la logique qui anime votre script et que vous n'obtenez pas le résultat attendu.

Vous ne pouvez pas détecter ces erreurs, car le type de logique que vous souhaitez mettre dans votre programme dépend des besoins de votre entreprise.

Par exemple, diviser un nombre par zéro ou un script écrit qui entre en boucle infinie.

Objet Err

Supposons que si nous avons une erreur d'exécution, l'exécution s'arrête en affichant le message d'erreur. En tant que développeur, si nous voulons capturer l'erreur, alorsError L'objet est utilisé.

Exemple

Dans l'exemple suivant, Err.Number donne le numéro d'erreur et Err.Description donne la description de l'erreur.

Err.Raise 6   ' Raise an overflow error.
MsgBox "Error # " & CStr(Err.Number) & " " & Err.Description
Err.Clear   ' Clear the error.

La gestion des erreurs

VBA active une routine de gestion des erreurs et peut également être utilisé pour désactiver une routine de gestion des erreurs. Sans une instruction On Error, toute erreur d'exécution qui se produit est fatale: un message d'erreur s'affiche et l'exécution s'arrête brusquement.

On Error { GoTo [ line | 0 | -1 ] | Resume Next }

Sr.No. Mot-clé et description
1

GoTo line

Active la routine de gestion des erreurs qui commence à la ligne spécifiée dans l'argument de ligne requis. La ligne spécifiée doit suivre la même procédure que l'instruction On Error, sinon une erreur de compilation se produira.

2

GoTo 0

Désactive le gestionnaire d'erreurs activé dans la procédure en cours et le réinitialise à Nothing.

3

GoTo -1

Désactive l'exception activée dans la procédure actuelle et la réinitialise à Nothing.

4

Resume Next

Spécifie que lorsqu'une erreur d'exécution se produit, le contrôle accède à l'instruction immédiatement après l'instruction où l'erreur s'est produite, et l'exécution se poursuit à partir de ce point.

Exemple

Public Sub OnErrorDemo()
   On Error GoTo ErrorHandler   ' Enable error-handling routine.
   Dim x, y, z As Integer
   x = 50
   y = 0
   z = x / y   ' Divide by ZERO Error Raises
  
   ErrorHandler:    ' Error-handling routine.
   Select Case Err.Number   ' Evaluate error number.
      Case 10   ' Divide by zero error
         MsgBox ("You attempted to divide by zero!")
      Case Else
         MsgBox "UNKNOWN ERROR  - Error# " & Err.Number & " : " & Err.Description
   End Select
   Resume Next
End Sub

Lors de la programmation à l'aide de VBA, il y a peu d'objets importants auxquels un utilisateur serait confronté.

  • Objets d'application
  • Objets de classeur
  • Objets de feuille de calcul
  • Objets de plage

Objets d'application

L'objet Application se compose des éléments suivants:

  • Paramètres et options à l'échelle de l'application.
  • Méthodes qui renvoient des objets de niveau supérieur, tels que ActiveCell, ActiveSheet, etc.

Exemple

'Example 1 :
Set xlapp = CreateObject("Excel.Sheet") 
xlapp.Application.Workbooks.Open "C:\test.xls"

'Example 2 :
Application.Windows("test.xls").Activate

'Example 3:
Application.ActiveCell.Font.Bold = True

Objets de classeur

L'objet Workbook est membre de la collection Workbooks et contient tous les objets Workbook actuellement ouverts dans Microsoft Excel.

Exemple

'Ex 1 : To close Workbooks
Workbooks.Close

'Ex 2 : To Add an Empty Work Book
Workbooks.Add

'Ex 3: To Open a Workbook
Workbooks.Open FileName:="Test.xls", ReadOnly:=True

'Ex : 4 - To Activate WorkBooks
Workbooks("Test.xls").Worksheets("Sheet1").Activate

Objets de feuille de calcul

L'objet Worksheet est membre de la collection Worksheets et contient tous les objets Worksheet d'un classeur.

Exemple

'Ex 1 : To make it Invisible
Worksheets(1).Visible = False

'Ex 2 : To protect an WorkSheet
Worksheets("Sheet1").Protect password:=strPassword, scenarios:=True

Objets de plage

Les objets de plage représentent une cellule, une ligne, une colonne ou une sélection de cellules contenant un ou plusieurs blocs continus de cellules.

'Ex 1 : To Put a value in the cell A5
Worksheets("Sheet1").Range("A5").Value = "5235"

'Ex 2 : To put a value in range of Cells
Worksheets("Sheet1").Range("A1:A4").Value = 5

Vous pouvez également lire un fichier Excel et écrire le contenu de la cellule dans un fichier texte à l'aide de VBA. VBA permet aux utilisateurs de travailler avec des fichiers texte en utilisant deux méthodes -

  • Objet du système de fichiers
  • en utilisant la commande d'écriture

Objet du système de fichiers (FSO)

Comme son nom l'indique, les FSO aident les développeurs à travailler avec des lecteurs, des dossiers et des fichiers. Dans cette section, nous verrons comment utiliser un FSO.

Sr.No. Type d'objet et description
1

Drive

Le lecteur est un objet. Contient des méthodes et des propriétés qui vous permettent de collecter des informations sur un lecteur connecté au système.

2

Drives

Drives est une collection. Il fournit une liste des lecteurs connectés au système, physiquement ou logiquement.

3

File

Le fichier est un objet. Il contient des méthodes et des propriétés qui permettent aux développeurs de créer, supprimer ou déplacer un fichier.

4

Files

Les fichiers sont une collection. Il fournit une liste de tous les fichiers contenus dans un dossier.

5

Folder

Le dossier est un objet. Il fournit des méthodes et des propriétés qui permettent aux développeurs de créer, supprimer ou déplacer des dossiers.

6

Folders

Folders est une collection. Il fournit une liste de tous les dossiers d'un dossier.

sept

TextStream

TextStream est un objet. Il permet aux développeurs de lire et d'écrire des fichiers texte.

Conduire

Driveest un objet qui permet d'accéder aux propriétés d'un lecteur de disque ou d'un partage réseau particulier. Les propriétés suivantes sont prises en charge parDrive objet -

  • AvailableSpace
  • DriveLetter
  • DriveType
  • FileSystem
  • FreeSpace
  • IsReady
  • Path
  • RootFolder
  • SerialNumber
  • ShareName
  • TotalSize
  • VolumeName

Exemple

Step 1- Avant de passer au script à l'aide de FSO, nous devons activer Microsoft Scripting Runtime. Pour faire de même, accédez à Outils → Références comme indiqué dans la capture d'écran suivante.

Step 2 - Ajoutez "Microsoft Scripting RunTime" et cliquez sur OK.

Step 3 - Ajoutez les données que vous souhaitez écrire dans un fichier texte et ajoutez un bouton de commande.

Step 4 - Il est maintenant temps de Script.

Private Sub fn_write_to_text_Click()
   Dim FilePath As String
   Dim CellData As String
   Dim LastCol As Long
   Dim LastRow As Long
  
   Dim fso As FileSystemObject
   Set fso = New FileSystemObject
   Dim stream As TextStream
  
   LastCol = ActiveSheet.UsedRange.Columns.Count
   LastRow = ActiveSheet.UsedRange.Rows.Count
    
   ' Create a TextStream.
   Set stream = fso.OpenTextFile("D:\Try\Support.log", ForWriting, True)
  
   CellData = ""
  
   For i = 1 To LastRow
      For j = 1 To LastCol
         CellData = Trim(ActiveCell(i, j).Value)
         stream.WriteLine "The Value at location (" & i & "," & j & ")" & CellData
      Next j
   Next i
  
   stream.Close
   MsgBox ("Job Done")
End Sub

Production

Lors de l'exécution du script, assurez-vous de placer le curseur dans la première cellule de la feuille de calcul. Le fichier Support.log est créé comme indiqué dans la capture d'écran suivante sous "D: \ Try".

Le contenu du fichier est présenté dans la capture d'écran suivante.

Commande d'écriture

Contrairement à FSO, nous n'avons pas besoin d'ajouter de références, cependant, nous ne pourrons PAS travailler avec des lecteurs, des fichiers et des dossiers. Nous pourrons simplement ajouter le flux au fichier texte.

Exemple

Private Sub fn_write_to_text_Click()
   Dim FilePath As String
   Dim CellData As String
   Dim LastCol As Long
   Dim LastRow As Long
  
   LastCol = ActiveSheet.UsedRange.Columns.Count
   LastRow = ActiveSheet.UsedRange.Rows.Count
    
   FilePath = "D:\Try\write.txt"
   Open FilePath For Output As #2
  
   CellData = ""
   For i = 1 To LastRow
      For j = 1 To LastCol
         CellData = "The Value at location (" & i & "," & j & ")" & Trim(ActiveCell(i, j).Value)
         Write #2, CellData
      Next j
   Next i
  
   Close #2
   MsgBox ("Job Done")
End Sub

Production

Lors de l'exécution du script, le fichier "write.txt" est créé à l'emplacement "D: \ Try" comme illustré dans la capture d'écran suivante.

Le contenu du fichier est illustré dans la capture d'écran suivante.

En utilisant VBA, vous pouvez générer des graphiques en fonction de certains critères. Jetons-y un coup d'œil à l'aide d'un exemple.

Step 1 - Entrez les données par rapport auxquelles le graphique doit être généré.

Step 2 - Créez 3 boutons - un pour générer un graphique à barres, un autre pour générer un graphique à secteurs et un autre pour générer un histogramme.

Step 3 - Développer une macro pour générer chacun de ces types de graphiques.

' Procedure to Generate Pie Chart
Private Sub fn_generate_pie_graph_Click()
   Dim cht As ChartObject
   For Each cht In Worksheets(1).ChartObjects
      cht.Chart.Type = xlPie
   Next cht
End Sub

' Procedure to Generate Bar Graph
Private Sub fn_Generate_Bar_Graph_Click()
   Dim cht As ChartObject
   For Each cht In Worksheets(1).ChartObjects
      cht.Chart.Type = xlBar
   Next cht
End Sub

' Procedure to Generate Column Graph
Private Sub fn_generate_column_graph_Click()
   Dim cht As ChartObject
   For Each cht In Worksheets(1).ChartObjects
      cht.Chart.Type = xlColumn
   Next cht
End Sub

Step 4- En cliquant sur le bouton correspondant, le graphique est créé. Dans la sortie suivante, cliquez sur le bouton générer un graphique à secteurs.

UNE User Formest une boîte de dialogue personnalisée qui rend la saisie de données utilisateur plus contrôlable et plus facile à utiliser pour l'utilisateur. Dans ce chapitre, vous apprendrez à concevoir un formulaire simple et à ajouter des données dans Excel.

Step 1- Accédez à la fenêtre VBA en appuyant sur Alt + F11 et accédez au menu "Insertion" et sélectionnez "Formulaire utilisateur". Lors de la sélection, le formulaire utilisateur s'affiche comme illustré dans la capture d'écran suivante.

Step 2 - Concevez les formulaires en utilisant les contrôles donnés.

Step 3- Après avoir ajouté chaque contrôle, les contrôles doivent être nommés. La légende correspond à ce qui apparaît sur le formulaire et le nom correspond au nom logique qui apparaîtra lorsque vous écrivez le code VBA pour cet élément.

Step 4 - Voici les noms de chacun des contrôles ajoutés.

Contrôle Nom logique Légende
De frmempform Formulaire d'employé
Boîte d'étiquette d'identification d'employé empid ID d'employé
boîte d'étiquette prénom Prénom Prénom
Nom de la boîte d'étiquette nom de famille Nom de famille
Boîte d'étiquettes dob dob Date de naissance
Boîte d'étiquettes mailid mailid ID e-mail
Boîte d'étiquettes de détenteur de passeport Titulaire du passeport Titulaire du passeport
Zone de texte Emp ID txtempid N'est pas applicable
Zone de texte du prénom txtfirstname N'est pas applicable
Zone de texte Nom txtlastname N'est pas applicable
Zone de texte de l'ID d'e-mail txtemailid N'est pas applicable
Zone de liste déroulante Date cmbdate N'est pas applicable
Zone de liste déroulante Mois cmbmonth N'est pas applicable
Boîte combo Année année N'est pas applicable
Bouton radio Oui radioyes Oui
Pas de bouton radio radiono Non
Bouton de soumission btnsubmit Soumettre
Bouton Annuler btncannuler Annuler

Step 5 - Ajoutez le code de l'événement de chargement du formulaire en effectuant un clic droit sur le formulaire et en sélectionnant «Afficher le code».

Step 6 - Sélectionnez 'Userform' dans la liste déroulante des objets et sélectionnez la méthode 'Initialize' comme indiqué dans la capture d'écran suivante.

Step 7 - Lors du chargement du formulaire, assurez-vous que les zones de texte sont effacées, que les listes déroulantes sont remplies et que les boutons radio sont réinitialisés.

Private Sub UserForm_Initialize()
   'Empty Emp ID Text box and Set the Cursor 
   txtempid.Value = ""
   txtempid.SetFocus
   
   'Empty all other text box fields
   txtfirstname.Value = ""
   txtlastname.Value = ""
   txtemailid.Value = ""
   
   'Clear All Date of Birth Related Fields
   cmbdate.Clear
   cmbmonth.Clear
   cmbyear.Clear
   
   'Fill Date Drop Down box - Takes 1 to 31
   With cmbdate
      .AddItem "1"
      .AddItem "2"
      .AddItem "3"
      .AddItem "4"
      .AddItem "5"
      .AddItem "6"
      .AddItem "7"
      .AddItem "8"
      .AddItem "9"
      .AddItem "10"
      .AddItem "11"
      .AddItem "12"
      .AddItem "13"
      .AddItem "14"
      .AddItem "15"
      .AddItem "16"
      .AddItem "17"
      .AddItem "18"
      .AddItem "19"
      .AddItem "20"
      .AddItem "21"
      .AddItem "22"
      .AddItem "23"
      .AddItem "24"
      .AddItem "25"
      .AddItem "26"
      .AddItem "27"
      .AddItem "28"
      .AddItem "29"
      .AddItem "30"
      .AddItem "31"
   End With
   
   'Fill Month Drop Down box - Takes Jan to Dec
   With cmbmonth
      .AddItem "JAN"
      .AddItem "FEB"
      .AddItem "MAR"
      .AddItem "APR"
      .AddItem "MAY"
      .AddItem "JUN"
      .AddItem "JUL"
      .AddItem "AUG"
      .AddItem "SEP"
      .AddItem "OCT"
      .AddItem "NOV"
      .AddItem "DEC"
   End With
   
   'Fill Year Drop Down box - Takes 1980 to 2014
   With cmbyear
      .AddItem "1980"
      .AddItem "1981"
      .AddItem "1982"
      .AddItem "1983"
      .AddItem "1984"
      .AddItem "1985"
      .AddItem "1986"
      .AddItem "1987"
      .AddItem "1988"
      .AddItem "1989"
      .AddItem "1990"
      .AddItem "1991"
      .AddItem "1992"
      .AddItem "1993"
      .AddItem "1994"
      .AddItem "1995"
      .AddItem "1996"
      .AddItem "1997"
      .AddItem "1998"
      .AddItem "1999"
      .AddItem "2000"
      .AddItem "2001"
      .AddItem "2002"
      .AddItem "2003"
      .AddItem "2004"
      .AddItem "2005"
      .AddItem "2006"
      .AddItem "2007"
      .AddItem "2008"
      .AddItem "2009"
      .AddItem "2010"
      .AddItem "2011"
      .AddItem "2012"
      .AddItem "2013"
      .AddItem "2014"
   End With
   
   'Reset Radio Button. Set it to False when form loads.
   radioyes.Value = False
   radiono.Value = False

End Sub

Step 8- Ajoutez maintenant le code au bouton Soumettre. En cliquant sur le bouton Soumettre, l'utilisateur doit être en mesure d'ajouter les valeurs dans la feuille de calcul.

Private Sub btnsubmit_Click()
   Dim emptyRow As Long
  
   'Make Sheet1 active
   Sheet1.Activate
  
   'Determine emptyRow
   emptyRow = WorksheetFunction.CountA(Range("A:A")) + 1
  
   'Transfer information
   Cells(emptyRow, 1).Value = txtempid.Value
   Cells(emptyRow, 2).Value = txtfirstname.Value
   Cells(emptyRow, 3).Value = txtlastname.Value
   Cells(emptyRow, 4).Value = cmbdate.Value & "/" & cmbmonth.Value & "/" & cmbyear.Value
   Cells(emptyRow, 5).Value = txtemailid.Value
  
   If radioyes.Value = True Then
      Cells(emptyRow, 6).Value = "Yes"
   Else
      Cells(emptyRow, 6).Value = "No"
   End If
End Sub

Step 9 - Ajoutez une méthode pour fermer le formulaire lorsque l'utilisateur clique sur le bouton Annuler.

Private Sub btncancel_Click()
   Unload Me
End Sub

Step 10- Exécutez le formulaire en cliquant sur le bouton "Exécuter". Entrez les valeurs dans le formulaire et cliquez sur le bouton «Soumettre». Automatiquement, les valeurs seront insérées dans la feuille de calcul, comme indiqué dans la capture d'écran suivante.