IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

VBA Word Discussion :

Rechercher Remplacer Mettre en forme conditionnelle sur x valeurs (guitare)


Sujet :

VBA Word

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Mars 2012
    Messages
    35
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Mars 2012
    Messages : 35
    Points : 28
    Points
    28
    Par défaut Rechercher Remplacer Mettre en forme conditionnelle sur x valeurs (guitare)
    Bonjour,

    Je récupère sur internet des tablatures de guitare lorsqu'elles m'intéressent (paroles et accords)
    Je créer un fichier par tab.

    Je souhaiterai mettre en forme le texte en mettant en valeur les accords (gras + couleur, bleu par exemple)
    La tache est immense sur plusieurs cetaines de fichiers. Je souhaite me simplifier la tache avec une macro, mais hors de ma portée technique.

    Je me suis inspiré d'un sujet de ce forum, mais je patine...
    Pour chaque accord, il faut que la macro recherche le texte, vérifie que la première lettre est en majuscule (car je suis un peu toqué lol), puis qu'elle mette en forme (cf ci dessus). Attention elle ne dois pas remplacer toutes les occurences puisqu'il se peut qu'une parole contienne les lettres de l'accord.

    Je m'explique, par exemple :

    tab1 :
    em am
    Je suis une cruche, percée de plus,

    Si bien qu'on doit rechercher pour l'accord em, selon moi, "espace em espace" "espace em tabulation" "espace em retour à la ligne" "tabulation em tabulation" etc etc je vous laisse deviner les possibilités.

    J'ai commencé par cela mais je pense être loin du compte:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    Sub GuitareMEF()
    Dim newNameem As String
    Dim oldNameem As String
    oldNameem = " em "
    newNameem = " Em "
     
    Dim newNameam As String
    Dim oldNameam As String
    oldNameam = " am "
    newNameam = " Am "
     
    ActiveDocument.Range.Select
    With Selection.Find
        .Text = oldNameem
        .Replacement.Text = newNameem
        .Forward = True
        .ClearFormatting
        .Wrap = wdFindContinue
        Selection.Font.Bold = wdToggle
    End With
     
    ActiveDocument.Range.Select
    With Selection.Find
        .Text = oldNameam
        .Replacement.Text = newNameam
        .Forward = True
        .ClearFormatting
        .Wrap = wdFindContinue
        Selection.Font.Bold = wdToggle
     
        .Execute Replace:=wdReplaceAll
     
     
     
    End With
    End Sub
    Il ne me remplace que les am ... (avec un espace avant et après)...
    Peut être auriez vous des fonctions vba pouvant me faciliter la tache.

    Merci d'avance

  2. #2
    Rédacteur/Modérateur

    Avatar de Heureux-oli
    Homme Profil pro
    Contrôleur d'industrie
    Inscrit en
    Février 2006
    Messages
    21 087
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 59
    Localisation : Belgique

    Informations professionnelles :
    Activité : Contrôleur d'industrie
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 21 087
    Points : 42 926
    Points
    42 926
    Par défaut
    Salut,

    Ce n'est pas la bonne voie, mettre les données en dur dans le code est une mauvaise solution.
    Chaque fois que tu vas souhaiter modifier quelque chose, tu vas devoir intervenir sur le code. Ton code va devenir très rapidement une usine à gaz.

    Jette un œil à ce tuto pour voir si rien ne peut t'aider.
    Je pense que ce sera le cas.

    http://heureuxoli.developpez.com/off...-et-remplacer/
    J'ai pas encore de décodeur, alors, postez en clair ! Comment mettre une balise de code ?
    Débutez en VBA

    Mes articles


    Dans un MP, vous pouvez me dire que je suis beau, ... mais si c'est une question technique je ne la lis pas ! Vous êtes prévenus !

  3. #3
    Nouveau membre du Club
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Mars 2012
    Messages
    35
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Mars 2012
    Messages : 35
    Points : 28
    Points
    28
    Par défaut re
    j'ai tout lu attentivement mais ce n'est pas facile de combiner le tout. Dès que je me base sur les exemples et que je rajoute un bout de code cela ne fonctionne plus. Je ne dois pas faire comme il faut fiou

Discussions similaires

  1. Réponses: 1
    Dernier message: 10/12/2007, 23h19
  2. Mise en forme conditionnelle sur une date ?
    Par byloute dans le forum Excel
    Réponses: 2
    Dernier message: 21/11/2007, 15h57
  3. Mise en forme conditionnelle sur condition
    Par rimbaut dans le forum Excel
    Réponses: 3
    Dernier message: 09/08/2007, 08h43
  4. Réponses: 2
    Dernier message: 11/01/2007, 11h18
  5. Réponses: 4
    Dernier message: 15/11/2005, 18h53

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo