Fatigué d'effectuer des tâches répétitives dans Microsoft Word? Enterré dans le programme est un puissant outil d'automatisation qui peut vous enlever ces tâches. Nous parlons de macros, et bien que la fonctionnalité repose sur le Visual Basic pour Applications (VBA) de Microsoft, vous pouvez l’utiliser même si l’idée de codage vous donne le courage.
En cliquant sur un bouton, Word enregistrera vos actions, générant une macro que vous pourrez rejouer aussi souvent que vous le souhaitez. Si vous êtes aventureux, vous pouvez facilement modifier la macro pour un degré d’automatisation supplémentaire.
Nous allons vous montrer ici un exemple simple mais utile: comment automatiser la fonction Rechercher et remplacer de Word.
Enregistrer la macro
Dans cet exemple, vous êtes le président estimé de la Society for the Preservation of Antique Dental Appliances. Vous avez des dizaines de documents Word sur les prothèses historiques et autres, tous avec le nom de la société en évidence. Puis, soudainement, le conseil vote pour changer le nom de la Dental Antiques Preservation League. Vous avez maintenant besoin d'un moyen simple de mettre à jour les documents.
Vous pouvez commencer avec un nouveau document vierge ou en ouvrir un existant. Si vous ne l'avez pas déjà fait, vous devrez activer l'onglet Développeur.
Aller à Fichier> Options> Personnaliser le ruban. Sur la droite, sous Onglets principaux, vérifier la Développeur option. Sélectionnez OK et quittez.
Créons maintenant notre macro.
- Cliquez sur Développeur> Enregistrer une macro.
- Vous serez invité à nommer la macro. Entrez «ChangeSocietyName» ou tout autre nom qui vous convient. Lorsque vous nommez des macros, évitez les espaces, les points, les points d'exclamation et les caractères spéciaux, sinon vous obtiendrez un message d'erreur. Vous pouvez utiliser des nombres, mais le premier caractère doit être une lettre.
- Vous pouvez attribuer la macro à un bouton et / ou à un raccourci clavier, mais ce n'est pas obligatoire. Si vous choisissez Button, Word vous permettra de l'ajouter à la barre d'outils d'accès rapide. Vous pouvez également ajouter une brève description de la macro.
- Cliquez sur d'accord, et Word enregistrera maintenant vos actions. Frapper Ctrl + H pour élever le Trouver et remplacer dialogue.
- Entrez «Society for the Preservation of Antique Dental Appliances» dans Find et «Dental Antique Preservation League» dans Replace.
- Cliquez sur Remplace tout pour exécuter l'opération Rechercher et remplacer. C'est la seule action que vous souhaitez enregistrer. Peu importe si la macro remplace réellement un texte. Le but est de le sauvegarder pour d'autres documents.
- Ceci est important: cliquez sur Développeur> Arrêter l'enregistrement. Sinon, la macro inclura toutes les actions suivantes.
Voyons maintenant votre travail. Ouvrez un document contenant le nom de la société. Cliquez sur Développeur> Macros. Si vous double-cliquez sur ChangeSocietyName, Word effectuera automatiquement l'opération Rechercher et remplacer.
Conseil: Lorsque vous enregistrez la macro, vous devrez peut-être effectuer une action que vous ne souhaitez pas enregistrer. Par exemple, vous souhaiterez peut-être copier et coller du texte dans la boîte de dialogue Rechercher et remplacer plutôt que de le saisir manuellement. Pas de problème: il suffit de cliquer Développeur> Mettre l'enregistrement en pause, copiez et collez le texte, puis cliquez sur Développeur> Enregistreur de CV. Ensuite, vous pouvez terminer l'enregistrement de la macro comme décrit ci-dessus.
Bien que nous nous soyons concentrés ici sur Microsoft Word, vous pouvez également utiliser des macros pour augmenter la productivité dans Excel. Et il y a beaucoup de macros permettant de gagner du temps pour Microsoft OneNote.
Saviez-vous que vous pouviez automatiser les tâches répétitives dans Microsoft Excel à l'aide de macros? Nous allons vous montrer comment enregistrer une macro dans Excel 2016 pour gagner beaucoup de temps.
Plonger dans le code
Nous allons maintenant approfondir notre nouvelle macro Word. Aller à Développeur> Macros, mais au lieu de double-cliquer sur la macro, sélectionnez-la et cliquez sur Éditer. Cela ouvre l'éditeur Visual Basic, un environnement autonome pour la création d'applications VBA.
Cela peut sembler intimidant, mais vous pouvez ignorer les menus et la plupart des panneaux. Concentrez-vous plutôt sur la fenêtre contenant le code. Comme vous pouvez le voir, Word vient d'écrire une macro qui effectue la recherche et le remplacement.
Sous ChangeSocietyName ()
'
Macro ChangeSocietyName
'Renommer la société pour la préservation des appareils dentaires antiques
'
Sélection. Trouver. Supprimer le formattage
Sélection. Trouver. Remplacement. Supprimer le formattage
Avec sélection. Trouver
.Text = "Société pour la conservation des appareils dentaires antiques"
.Remplacement. Text = "Ligue de préservation des antiquités dentaires"
.Forward = Vrai
.Wrap = wdFindContinue
.Format = Faux
.MatchCase = Faux
.MatchWholeWord = Faux
.MatchWildcards = Faux
.MatchSoundsLike = Faux
.MatchAllWordForms = Faux
Terminer par
Sélection. Trouver. Exécuter le remplacement: = wdReplaceAll
End Sub
Expliquons ce qui se passe ici.
Le «sous» sur la première ligne est l'abréviation de «sous-programme», un petit programme qui peut s'exécuter seul ou dans le cadre d'une application VBA plus grande. Les lignes précédées de guillemets simples sont destinées aux commentaires. Les guillemets indiquent à VBA d'ignorer toutes les instructions sur ces lignes.
Ensuite, nous arrivons à la viande du code: le code qui exécute le Trouver et remplacer opération. Comme vous pouvez le voir, il spécifie des valeurs pour chaque option dans la boîte de dialogue Rechercher et remplacer, y compris le texte et le texte de remplacement entre guillemets. Le Sélection. Trouver. Exécuter la commande vers la fin équivaut à cliquer sur le bouton «Tout remplacer».
Modifier la macro
Pour utiliser des macros, vous n’avez pas à vous soucier du code ni même à le regarder. Mais vous pouvez tirer le meilleur parti de cette fonction si vous êtes prêt à vous lancer. Par exemple, supposons que vous faites une faute de frappe lors de l'enregistrement de la macro. Au lieu de le réenregistrer, vous pouvez accéder à Visual Basic et le corriger.
Vous pouvez également modifier la macro pour la rendre plus utile, et c'est ce que nous allons faire ici. Lorsque vous exécutez Rechercher et remplacer, que ce soit manuellement ou via une macro, Word se souvient du texte de recherche et de remplacement. La prochaine fois que vous ouvrirez la boîte de dialogue Rechercher et remplacer, elle ressemblera à ceci.
Il serait préférable d'effacer les valeurs pour obtenir une boîte de dialogue propre. Nous le ferons avec une deuxième macro, sauf que cette fois, nous le ferons directement dans Visual Basic.
- Dans l'éditeur Visual Basic, sélectionnez le sous-programme entier, de la première ligne à End Sub. Frapper Ctrl + C pour le copier.
- Placez le curseur sous End Sub et appuyez sur Ctrl + V. Vous venez de dupliquer le sous-programme.
- Changez le nom de ChangeSocietyName en ClearFindReplace (ou tout autre nom qui vous convient). Ceci est important car VBA générera un message d'erreur si vous essayez d'exécuter des macros avec des noms en double.
- Dans le .Texte et Remplacement. Texte valeurs, supprimez le texte mais laissez les guillemets. Essentiellement, vous dites à Word de ne rien trouver et de le remplacer par rien, mais vous effacez également ces valeurs.
Le résultat devrait ressembler à ceci:
Sous ClearFindReplace ()
'
Macro ClearFindReplace
'Effacer le texte de la boîte de dialogue Rechercher et remplacer
'
Sélection. Trouver. Supprimer le formattage
Sélection. Trouver. Remplacement. Supprimer le formattage
Avec sélection. Trouver
.Text = ""
.Remplacement. Texte = ""
.Forward = Vrai
.Wrap = wdFindContinue
.Format = Faux
.MatchCase = Faux
.MatchWholeWord = Faux
.MatchWildcards = Faux
.MatchSoundsLike = Faux
.MatchAllWordForms = Faux
Terminer par
Sélection. Trouver. Exécuter le remplacement: = wdReplaceAll
End Sub
Nous allons maintenant revenir à la macro ChangeSocietyName. Sous le code Rechercher et remplacer, mais avant End Sub, entrez ClearFindReplace (sans parenthèses à la fin).
C'est vrai: vous n'êtes pas obligé de saisir tout le code que vous venez de créer, mais uniquement le nom de la macro.
Sous ChangeSocietyName ()
'
Macro ChangeSocietyName
'Renommer la société pour la préservation des appareils dentaires antiques
'
Sélection. Trouver. Supprimer le formattage
Sélection. Trouver. Remplacement. Supprimer le formattage
Avec sélection. Trouver
.Text = "Société pour la conservation des appareils dentaires antiques"
.Remplacement. Text = "Ligue de préservation des antiquités dentaires"
.Forward = Vrai
.Wrap = wdFindContinue
.Format = Faux
.MatchCase = Faux
.MatchWholeWord = Faux
.MatchWildcards = Faux
.MatchSoundsLike = Faux
.MatchAllWordForms = Faux
Terminer par
Sélection. Trouver. Exécuter le remplacement: = wdReplaceAll
ClearFindReplace
End Sub
Lorsque Word exécute ChangeSocietyName, il exécute d'abord la fonction Rechercher et remplacer d'origine. Ensuite, il interprétera ClearFindReplace comme une commande pour exécuter la deuxième macro.
Aller plus loin avec VBA
Comme vous pouvez le constater, la fonction d’enregistrement de macros de Word peut vous aider à gagner du temps de nombreuses manières. Vous pouvez créer des macros pour automatiser presque toutes les opérations, et dans l'éditeur Visual Basic, vous pouvez modifier le macros, incorporez une macro dans l'autre ou créez un sous-programme qui exécute plusieurs macros l'une après autre.
Étant donné que VBA est un langage de programmation à part entière, vous pouvez incorporer les sous-programmes dans des applications plus volumineuses avec des variables, des boucles, des instructions conditionnelles, etc. Et une fois que vous avez appris les bases de VBA dans Word, vous pouvez appliquer une grande partie de ces mêmes connaissances pour créer des macros dans Microsoft Excel et Access.
Pour aller plus loin, vous voudrez en savoir plus sur les conventions VBA et l'éditeur Visual Basic, comme comment organiser votre code et comment gérer les bogues. Mais même si vous souhaitez vous en tenir à des fonctions simples comme celles décrites ici, vous pouvez grandement améliorer votre productivité.
Si vous utilisez Excel régulièrement, cela vaut la peine d'apprendre à créer des macros VBA et d'accéder à de nombreuses autres fonctions et capacités.
- Productivité
- Microsoft Word
- Microsoft Office 365
- Microsoft Office 2016
- Conseils Microsoft Office
- Microsoft Office 2019
- Macros
Stephen Beale est un écrivain technologique de longue date basé dans la région de San Francisco. Il est l'auteur de nombreux livres sur les applications informatiques dans l'édition et la conception graphique, et est un ancien éditeur de nouvelles et de critiques pour Macworld. Il dirige actuellement The Steampunk Explorer, un site Web populaire pour les amateurs de steampunk.
Abonnez-vous à notre newsletter
Rejoignez notre newsletter pour des conseils techniques, des critiques, des ebooks gratuits et des offres exclusives!
Un pas de plus…!
Veuillez confirmer votre adresse e-mail dans l'e-mail que nous venons de vous envoyer.