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

Macros et VBA Excel Discussion :

Macro pour supprimer les espaces dans les cellules [XL-2007]


Sujet :

Macros et VBA Excel

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Data Processor
    Inscrit en
    Novembre 2009
    Messages
    37
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Data Processor
    Secteur : Conseil

    Informations forums :
    Inscription : Novembre 2009
    Messages : 37
    Points : 32
    Points
    32
    Par défaut Macro pour supprimer les espaces dans les cellules
    Bonjour,

    J'aimerais créer une macro pour supprimer les espaces dans toutes les feuilles de mon fichier excell (sheet1 à sheet5).

    1. Supprimer tous les espaces dans les cellules qui ne contiennent aucun caractère, et ce dans toutes les sheets.
    2. Supprimer tous les espaces dans les cellules qui contiennent des caractères (mots ou chiffres) après le dernier caractère (à droite), et ce dans toutes les sheets.

    Pouvez-vous m'aider à réaliser cette macro ?

    Merci d'avance

    Anthony

  2. #2
    Membre chevronné Avatar de Krovax
    Profil pro
    Inscrit en
    Juillet 2008
    Messages
    1 888
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France

    Informations forums :
    Inscription : Juillet 2008
    Messages : 1 888
    Points : 2 168
    Points
    2 168
    Par défaut
    Bonjour
    Oui on peux t'aider.
    Mais on te laisse commencer, aider n'est pas faire à la place.

    Alors si tu veux des indications pour commencer
    Pour supprimer les espace à droite point 2
    http://silkyroad.developpez.com/VBA/...racteres/#LI-M

    Pour le point 1 un espace est un caractère difficile de supprimer les espace là ou il n'y a pas de caractère

    Mais essaye de voir si la fonction trim te suffit
    S'il n'y as que des espcae elle semble tous les supprimer

    Après il te suffit de boucler sur les onglet
    exemple
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    dim ws as worksheet
    for each ws in worksheets
    ...
    next ws
    Boucler sur les cellule de l'onglet en cours
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    dim c as range
    for each c in ws.UsedRange
     
    next c
    Voila tu devrais avoir tout il va peut être te faloir tester c en fonction de tes besoins. Mais ca te permettra de commencer ton code. Tu nous le montre et tu nous explique ce qui ne va pas
    Bonne chance

    edit en fonction du format de ton fichier le UsedRange peut poser problème regarde ici si c'est le cas pour trouver la dernièreligne et dernière colonne
    « Il n'y a pas de recette miracle qui permet aux gens d’écrire des programmes corrects sans avoir à réfléchir. Il faut apprendre aux gens comment réfléchir »

  3. #3
    Membre averti
    Homme Profil pro
    Formateur en informatique
    Inscrit en
    Janvier 2007
    Messages
    1 144
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Vienne (Poitou Charente)

    Informations professionnelles :
    Activité : Formateur en informatique

    Informations forums :
    Inscription : Janvier 2007
    Messages : 1 144
    Points : 337
    Points
    337
    Par défaut
    Salut,

    Pour le 1, j'ai une solution mais j'aimerais d'abord comprendre ce que tu veux pour le 2?

    En gros tu as :

    Une Chaine+Un espace?
    Et tu veux supprimer uniquement l'espace de la fin?

  4. #4
    Nouveau membre du Club
    Homme Profil pro
    Data Processor
    Inscrit en
    Novembre 2009
    Messages
    37
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Data Processor
    Secteur : Conseil

    Informations forums :
    Inscription : Novembre 2009
    Messages : 37
    Points : 32
    Points
    32
    Par défaut
    Merci Krovax,

    Voila ce que j'ai copier dans les macros de mon fichier et cela marche très bien. J'y ai lié un bouton dans mon fichier pour plus de facilité.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Sheets("Sheet1").Select
    Dim x1 As Range
    For Each x1 In ActiveSheet.UsedRange
        x1 = Application.WorksheetFunction.Trim(x1)
    Next
    J'ai juste encore une question :
    Pour éviter de devoir écrire cela pour chaque sheet, y a-t-il un moyen d'exécuter cette macro directement sur toutes les sheets ?

    Merci encore.

    Anthony

  5. #5
    Inactif  
    Avatar de ouskel'n'or
    Profil pro
    Inscrit en
    Février 2005
    Messages
    12 464
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 12 464
    Points : 15 543
    Points
    15 543
    Par défaut
    Bonjour vousss !
    Et "Replace" n'existe pas dans la version 2007 d'Excel pour remplacer les espaces par rien, pour la première question ?
    Rtrim, Ltrim et trim n'existe pas non plus pour supprimer les espaces à droite , à gauche ou à droite et à gauche ou encore à droite ET à gauche ?
    Bonnes études

  6. #6
    Membre chevronné Avatar de Krovax
    Profil pro
    Inscrit en
    Juillet 2008
    Messages
    1 888
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France

    Informations forums :
    Inscription : Juillet 2008
    Messages : 1 888
    Points : 2 168
    Points
    2 168
    Par défaut
    Bonjour ousk

    Pour antony tu dis

    Citation Envoyé par ab1to Voir le message
    Pour éviter de devoir écrire cela pour chaque sheet, y a-t-il un moyen d'exécuter cette macro directement sur toutes les sheets ?
    regarde un peu plus haut

    Citation Envoyé par Krovax Voir le message
    Après il te suffit de boucler sur les onglet
    exemple
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    dim ws as worksheet
    for each ws in worksheets
    ...
    next ws
    DOnc lit mon message et utilise ce que j'y ai dis, tu as un tutos, l'aide et le nom des fonctions donc bonne chance
    « Il n'y a pas de recette miracle qui permet aux gens d’écrire des programmes corrects sans avoir à réfléchir. Il faut apprendre aux gens comment réfléchir »

  7. #7
    Nouveau membre du Club
    Homme Profil pro
    Data Processor
    Inscrit en
    Novembre 2009
    Messages
    37
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Data Processor
    Secteur : Conseil

    Informations forums :
    Inscription : Novembre 2009
    Messages : 37
    Points : 32
    Points
    32
    Par défaut
    Ca y est ! Ca fonctionne ...


    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
    Sub Suppression_Espaces()
     
    Dim ws As Worksheet
       For Each ws In Worksheets
     
         Dim c As Range
         For Each c In ws.UsedRange
     
             'Suppression des espaces à droite
             c = RTrim(c)
     
         Next c
     
       Next wsSheets("Macro").Select
     
    End Sub
    Merci à tous.

  8. #8
    Inactif  
    Avatar de ouskel'n'or
    Profil pro
    Inscrit en
    Février 2005
    Messages
    12 464
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 12 464
    Points : 15 543
    Points
    15 543
    Par défaut
    Tu pouvais simplifier et accélérer la procédure en traitant pour chaque feuille la plage de données complète (usedrange) et non chaque cellule de cette plage (ce que fait ta boucle imbriquée)

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

Discussions similaires

  1. Supprimer l'espace dans les données
    Par Miachan99 dans le forum SAS Base
    Réponses: 2
    Dernier message: 13/11/2012, 13h40
  2. Réponses: 7
    Dernier message: 24/01/2012, 18h55
  3. Supprimé les espaces et les '\n' dans une chaine
    Par EricStib dans le forum Général Python
    Réponses: 6
    Dernier message: 04/01/2009, 18h02
  4. Réponses: 1
    Dernier message: 12/12/2006, 18h31
  5. ne veut pas d'espaces entre les images dans une cellule
    Par cortex024 dans le forum Mise en page CSS
    Réponses: 6
    Dernier message: 07/12/2006, 15h30

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