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 rechercher/remplacer sur toutes les feuilles


Sujet :

Macros et VBA Excel

  1. #1
    Nouveau Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2015
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Val d'Oise (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2015
    Messages : 4
    Points : 1
    Points
    1
    Par défaut macro rechercher/remplacer sur toutes les feuilles
    Bonjour,

    ayant un niveau 0 en vba, j'ai fait quelque recherche sur internet pour créer une macro.

    le but de la macro :
    - ouvrir une sélection de fichier excel
    - rechercher/remplacer plusieurs mots en changeant la couleur de la police
    - fermer les fichier ouvert

    le problème, c'est que cela marche que sur la feuille qui était active lors l'enregistrement.

    pouvez-vous regarder et me dire mon erreur.

    merci
    Fichiers attachés Fichiers attachés

  2. #2
    Expert éminent sénior Avatar de mercatog
    Homme Profil pro
    Inscrit en
    Juillet 2008
    Messages
    9 435
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Autre

    Informations forums :
    Inscription : Juillet 2008
    Messages : 9 435
    Points : 31 877
    Points
    31 877
    Par défaut
    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
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    Sub Remplacer()
    Dim Compteur As Byte
    Dim Liste As String
    Dim Wb As Workbook
    Dim Rep As Long
    Dim NomFich
     
    NomFich = Application.GetOpenFilename(Title:="Ouverture des fichiers CEXP", MultiSelect:=True)
     
    If TypeName(NomFich) = "Boolean" Then Exit Sub
     
    With Application.ReplaceFormat.Font
        .Subscript = False
        .Color = 255
        .TintAndShade = 0
    End With
     
    For Compteur = 1 To UBound(NomFich)
        Liste = Liste & vbCr & NomFich(Compteur)
    Next Compteur
     
    Rep = MsgBox("Voici la liste des fichiers CEXP sélectionnés." & Liste & vbCr & "Voulez-vous les ouvrir ?", vbYesNo + vbQuestion, "Ouvrir les fichiers CEXP ?")
    If Rep = vbYes Then
        For Compteur = 1 To UBound(NomFich)
            Set Wb = Workbooks.Open(NomFich(Compteur))
            Call Rempl(Wb)
            Set Wb = Nothing
        Next Compteur
    End If
    Application.ReplaceFormat.Clear
    End Sub
     
    Private Sub Rempl(ByVal Wbk As Workbook)
    Dim Feuil As Worksheet
     
    With Wbk
        For Each Feuil In .Worksheets
            With Feuil.UsedRange
                .Replace What:="-11", Replacement:="-21", LookAt:=xlPart, ReplaceFormat:=True
                .Replace What:="-13", Replacement:="-23", LookAt:=xlPart, ReplaceFormat:=True
                .Replace What:="-14", Replacement:="-24", LookAt:=xlPart, ReplaceFormat:=True
                .Replace What:="Train A", Replacement:="Train B", LookAt:=xlPart, ReplaceFormat:=True
            End With
        Next Feuil
     
        Application.DisplayAlerts = False
        .Close True
        Application.DisplayAlerts = False
    End With
    End Sub
    Cordialement.
    J'utilise toujours le point comme séparateur décimal dans mes tests.

  3. #3
    Nouveau Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2015
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Val d'Oise (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2015
    Messages : 4
    Points : 1
    Points
    1
    Par défaut
    merci !!!! ça marche !!!

    pourrais-je connaitre mes erreurs ?

    a+

  4. #4
    Expert éminent sénior Avatar de mercatog
    Homme Profil pro
    Inscrit en
    Juillet 2008
    Messages
    9 435
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Autre

    Informations forums :
    Inscription : Juillet 2008
    Messages : 9 435
    Points : 31 877
    Points
    31 877
    Par défaut
    Thisworkbook désigne le classeur contenant la macro
    Cordialement.
    J'utilise toujours le point comme séparateur décimal dans mes tests.

  5. #5
    Nouveau Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2015
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Val d'Oise (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2015
    Messages : 4
    Points : 1
    Points
    1
    Par défaut
    Bonjour,

    j'ai un problèe qui apparaît sur certain fichier

    "la méthode 'replace' de l'objet 'range' a échoué"

    merci encore pour ton aide.

    A+

  6. #6
    Expert éminent sénior Avatar de mercatog
    Homme Profil pro
    Inscrit en
    Juillet 2008
    Messages
    9 435
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Autre

    Informations forums :
    Inscription : Juillet 2008
    Messages : 9 435
    Points : 31 877
    Points
    31 877
    Par défaut
    Quel dommage!
    Cordialement.
    J'utilise toujours le point comme séparateur décimal dans mes tests.

  7. #7
    Nouveau Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2015
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Val d'Oise (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2015
    Messages : 4
    Points : 1
    Points
    1
    Par défaut
    désolé si j'ai fait quelque chose de mal mais dans tous les cas merci de m'avoir aidé.

    j'ai réglé le problème en changeant cette partie du code

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    For Each Feuil In .Worksheets
            With Feuil.UsedRange
                Cells.Select
                Selection.Replace What:="-11", Replacement:="-21", LookAt:=xlPart, ReplaceFormat:=True
                Selection.Replace What:="-13", Replacement:="-23", LookAt:=xlPart, ReplaceFormat:=True
                Selection.Replace What:="-14", Replacement:="-24", LookAt:=xlPart, ReplaceFormat:=True
                Selection.Replace What:="Train A", Replacement:="Train B", LookAt:=xlPart, ReplaceFormat:=True
            End With
     
        Next Feuil

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

Discussions similaires

  1. [XL-2003] macro impossible sur toutes les feuilles
    Par alucard_xs dans le forum Macros et VBA Excel
    Réponses: 13
    Dernier message: 04/06/2012, 22h23
  2. [XL-2007] Operations tableaux et boucle sur toutes les feuilles
    Par undercorejay dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 24/01/2010, 23h16
  3. Mise en page avant impression sur toutes les feuilles du classeur
    Par fribelle dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 12/11/2008, 09h48
  4. Récuperer le clique sur toutes les feuilles
    Par faube dans le forum Excel
    Réponses: 6
    Dernier message: 03/08/2007, 10h17
  5. Action sur toutes les feuilles d'un classeur
    Par beurnoir dans le forum Macros et VBA Excel
    Réponses: 14
    Dernier message: 23/12/2005, 15h11

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