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 :

Macro Recherche espaces sans tabulation


Sujet :

VBA Word

  1. #1
    Membre du Club
    Inscrit en
    Juin 2002
    Messages
    42
    Détails du profil
    Informations forums :
    Inscription : Juin 2002
    Messages : 42
    Points : 40
    Points
    40
    Par défaut Macro Recherche espaces sans tabulation
    Bonjour,

    Je suis en train de développer une petite macro qui fait une recherche des espaces dans un document Word pour supprimer les espaces successif.
    En gros je recherche les espaces grâce à la formule ^w

    Le problème est qu'il me trouve également les tabulations.
    Est-t'il possible de trouver les espaces sans les tabulations ?

    Merci

    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
    Sub TrimGlobal()
    '
    ' TrimGlobal Macro
    '
    '
    With Selection.Find
        .ClearFormatting
        .Text = "^w"
        .MatchWildcards = False
        .Replacement.ClearFormatting
        .Replacement.Text = " "
        .Execute Replace:=wdReplaceAll
    End With
     
    End Sub

  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,

    Pourquoi faire une macro ?

    Une simple recherche/remplacement devrait le faire.
    Tu recherches les doubles espaces et tu les remplaces par un espace simple.
    Si tu as quatres espaces, en deux passages ils seront remplacés par un seul espace.
    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
    Membre du Club
    Inscrit en
    Juin 2002
    Messages
    42
    Détails du profil
    Informations forums :
    Inscription : Juin 2002
    Messages : 42
    Points : 40
    Points
    40
    Par défaut
    Citation Envoyé par Heureux-oli Voir le message
    Salut,

    Pourquoi faire une macro ?

    Une simple recherche/remplacement devrait le faire.
    Tu recherches les doubles espaces et tu les remplaces par un espace simple.
    Si tu as quatres espaces, en deux passages ils seront remplacés par un seul espace.
    La macro sert a faciliter le travail d'utilisateur suite à un publipostage qui utilise des donnés venant d'un fichier csv. Les données contiennent des espaces en trop dans les champs car ce sont des données de taille fixe.

    Oui j'ai déjà pensé à faire une recherche sur le double espace mais cette recherche pose problème quand mes mots sont séparés pas des double espace car dans ces cas là les mots se retrouvent collés.

  4. #4
    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,

    Les mots collés ?
    Si tu remplace deux espaces par un seul, les mots ne sauraient pas être collés.
    De toute façon, la macro que tu utilises fait la même chose que l'interface.
    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 !

  5. #5
    Membre du Club
    Inscrit en
    Juin 2002
    Messages
    42
    Détails du profil
    Informations forums :
    Inscription : Juin 2002
    Messages : 42
    Points : 40
    Points
    40
    Par défaut
    Citation Envoyé par Heureux-oli Voir le message
    Salut,

    Les mots collés ?
    Si tu remplace deux espaces par un seul, les mots ne sauraient pas être collés.
    De toute façon, la macro que tu utilises fait la même chose que l'interface.
    Oui j'ai mal lu, en effet il ne sont pas collés, mais je suis obligé d'executer plusieur fois le recherche remplacer

  6. #6
    Membre du Club
    Inscrit en
    Juin 2002
    Messages
    42
    Détails du profil
    Informations forums :
    Inscription : Juin 2002
    Messages : 42
    Points : 40
    Points
    40
    Par défaut
    Bonjour,

    J'ai résolu mon problème
    voici ce que je fais:
    Je boucle tant que la recherche avec des doubles espaces retourne un résultat. Comme ça le remplacement se fait correctement sans me supprimer les tabulations.

    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
     
    Sub TrimGlobal()
    '
    ' TrimGlobal Macro
    '
    '
        Do
            With Selection.Find
                .ClearFormatting
                .Text = "  "
                .MatchWildcards = False
                .Replacement.ClearFormatting
                .Replacement.Text = " "
                .Execute Replace:=wdReplaceAll
            End With
     
        Loop While Selection.Find.Found = True
     
    End Sub

Discussions similaires

  1. [XL-2003] Macro pour onglet sans espace
    Par Un Internaute dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 25/04/2014, 08h20
  2. Macro : .xls to .txt sans espace ni tabulation
    Par kyzeur dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 25/07/2007, 15h45
  3. Faire une recherche avec/sans accents
    Par Wedge3D dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 21/02/2007, 10h43
  4. Réponses: 4
    Dernier message: 26/05/2006, 11h39
  5. espace ou tabulation?
    Par caribou_belle dans le forum Langages de programmation
    Réponses: 27
    Dernier message: 05/10/2003, 11h57

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