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 chaîne + délimiteurs à remplacer par autres délimiteurs


Sujet :

VBA Word

  1. #1
    Futur Membre du Club
    Inscrit en
    Novembre 2007
    Messages
    27
    Détails du profil
    Informations forums :
    Inscription : Novembre 2007
    Messages : 27
    Points : 9
    Points
    9
    Par défaut Rechercher-remplacer chaîne + délimiteurs à remplacer par autres délimiteurs
    Bonjour,

    Je cherche à résoudre le problème suivant.

    Dans un fichier Word, j'ai des balises du type
    <}100{>
    <}90{>
    <}17{>

    Je souhaiterais faire un rechercher-remplacer afin d'obtenir
    [BM100]
    [BM90]
    [BM17]

    J'ai cherché à décomposer le problème en sous-étapes et ça me donne ça :
    1) Rechercher toute chaîne <}valeur_numérique{>.
    2) Pour chaque chaîne trouvée, extraire la valeur numérique et la stocker dans une variable (pour info, cette valeur numérique peut être comprise entre 0 et 100).
    3) Remplacer la chaîne trouvée par "[BM" + variable + "]".

    Pour cela, j'utilise les caractères génériques et la commande "MID" mais ça coince.

    Voici le code auquel je suis parvenu jusqu'à présent (quand j'aurai résolu le problème, je mettrai ce code dans une boucle pour remplacer toutes les occurrences du document mais j'ai essayé de simplifier au maximum pour l'instant).

    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
    37
    38
     
    Sub aMacro81()
     
     
    'Réinitalisation des paramètres de recherche
    Selection.Find.ClearFormatting
    Selection.Find.Replacement.ClearFormatting
     
    'Déclaration de la variable de balise du milieu, sBM, qui prend pour valeur le texte de la sélection
    sBM = Selection.Text
    ' Déclaration de la limite de droite, qui équivaut à la longueur de la chaîne moins 2 caractères ({>)
    compteCar = (Len(sBM) - 2)
    ' Déclaration de la variable contenant la valeur numérique extraite de la balise de milieu (extraction du 3e caractère à l'avant-avant-dernier charactère).
    sBMVAL = Mid(sBM, 3, compteCar)
    ' Déclaration de la variable de remplacement, concaténée sous la forme "[MT" + sBMVAL "]"
    sRemplacement = "[MT" & sBMVAL & "]"
     
     
        With Selection.Find
            .Text = "\<\}*\{\>"
            .Replacement.Text = sRemplacement
            .Forward = True
            .Wrap = wdFindStop
     
            .Format = False
            .MatchCase = False
            .MatchWholeWord = False
            .MatchAllWordForms = False
            .MatchSoundsLike = False
            .MatchWildcards = True
        End With
     
     
    Selection.Find.Execute Replace:=wdReplaceAll
     
     
     
    End Sub
    *******
    Voici également trois phrases d'exemple :

    {0>Show/hide the reference X, Y, and Z, axis in the 3D preview window.<}100{>Affichez/masquez l'axe de référence X, Y ou Z dans la fenêtre d'aperçu 3D.<0}
    {0>The reference 3D axis is useful while changing orientation of the 3D symbology.<}10{>L'axe 3D de référence est utile lors du changement d'orientation de la symbologie 3D.<0}

    {0>The red, green, and blue lines represent the X, Y, and Z, axis respectively.<}99{>Les lignes rouge, verte et bleue représentent les axes X, Y et Z, respectivement.<0}


    *******

    Si quelqu'un avait une idée, ça m'aiderait énormément (à noter que ce n'est pas urgent).

    Merci beaucoup.

    Lionel

  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,

    Perso, pour contourner les caractères spéciaux, j'utilise leur code ASCII.

    [ = Alt 91
    ] = Alt 93
    < = Alt 60

    ce qui donne en VBA :

    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
    Expert éminent
    Avatar de Sepia
    Homme Profil pro
    Administrateur du cursus IDE@L - Chef de Projet NCU (digital learning) - Université de Rennes
    Inscrit en
    Octobre 2007
    Messages
    3 117
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Administrateur du cursus IDE@L - Chef de Projet NCU (digital learning) - Université de Rennes
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Octobre 2007
    Messages : 3 117
    Points : 6 856
    Points
    6 856
    Par défaut Remplacement
    Salut,

    Word possède des mécanismes de remplacement très puissants. Dans ton cas, c'est très simple : la ruse consiste à ajouter des caractères devant ceux que tu veux...supprimer

    1. Remplacer global avec "<}^#" par "$$$^&"
    2. Remplacer global avec "$$$<}" par "[BM"
    3. Remplacer global avec "^#{>" par "^&$$$"
    4. Remplacer global avec "{>$$$" par "]"


    C'est fini

  4. #4
    Futur Membre du Club
    Inscrit en
    Novembre 2007
    Messages
    27
    Détails du profil
    Informations forums :
    Inscription : Novembre 2007
    Messages : 27
    Points : 9
    Points
    9
    Par défaut
    Citation Envoyé par Heureux-oli Voir le message
    Salut,

    Perso, pour contourner les caractères spéciaux, j'utilise leur code ASCII.

    [ = Alt 91
    ] = Alt 93
    < = Alt 60

    ce qui donne en VBA :

    Bonjour Heureux Oli,

    Merci beaucoup de ta réponse. J'intègre ça immédiatement à mon code.

    Merci encore.

    Lionel

  5. #5
    Futur Membre du Club
    Inscrit en
    Novembre 2007
    Messages
    27
    Détails du profil
    Informations forums :
    Inscription : Novembre 2007
    Messages : 27
    Points : 9
    Points
    9
    Par défaut
    Citation Envoyé par Sepia Voir le message
    Salut,

    Word possède des mécanismes de remplacement très puissants. Dans ton cas, c'est très simple : la ruse consiste à ajouter des caractères devant ceux que tu veux...supprimer

    1. Remplacer global avec "<}^#" par "$$$^&"
    2. Remplacer global avec "$$$<}" par "[BM"
    3. Remplacer global avec "^#{>" par "^&$$$"
    4. Remplacer global avec "{>$$$" par "]"


    C'est fini
    Bonjour Sepia,

    Génial, c'est le "^&" qu'il me manquait pour récupérer le contenu de la zone Rechercher ! J'avais essayé avec Mid, Val, etc. pour extraire la valeur numérique alors que c'est tellement plus direct avec le contenu de la zone Rechercher (et en plus, ça marche, alors que ça ne marchait pas avec mon code ;-)).

    Pour le reste, c'est exactement ce que je fais : des rechercher-remplacer partout afin d'obtenir une structure parfaitement symétrique, l'objectif final étant de convertir le tout en tableau de quatre colonnes (balise et formatages de départ, texte source, texte cible, balise et formatages de fin).

    Merci encore de ton aide.

    Bien cordialement,

    Lionel

  6. #6
    Expert éminent
    Avatar de Sepia
    Homme Profil pro
    Administrateur du cursus IDE@L - Chef de Projet NCU (digital learning) - Université de Rennes
    Inscrit en
    Octobre 2007
    Messages
    3 117
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Administrateur du cursus IDE@L - Chef de Projet NCU (digital learning) - Université de Rennes
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Octobre 2007
    Messages : 3 117
    Points : 6 856
    Points
    6 856
    Par défaut
    De rien

    A+

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Recherche une chaîne de caracteres par textbox sur BD
    Par BERRACHED SAID dans le forum Macros et VBA Excel
    Réponses: 12
    Dernier message: 10/05/2013, 22h03
  2. remplacer chaîne de caractere par une autre
    Par Invité(e) dans le forum Linux
    Réponses: 4
    Dernier message: 21/07/2010, 13h47
  3. Remplacer une chaîne de caractéres par une autre
    Par koKoTis dans le forum Linux
    Réponses: 6
    Dernier message: 15/10/2007, 09h00
  4. Réponses: 8
    Dernier message: 15/07/2006, 18h59
  5. remplacer le nom dns par autre chose
    Par griese dans le forum Apache
    Réponses: 11
    Dernier message: 06/07/2006, 16h32

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