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 :

Executer Macro d'un fichier A sur fichier B


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre actif
    Homme Profil pro
    Inscrit en
    Janvier 2012
    Messages
    18
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Janvier 2012
    Messages : 18
    Par défaut Executer Macro d'un fichier A sur fichier B
    Bonjour ,

    J'ai un fichier Excel qui est mis a jours tout les jours (Fichier B) et un autre ou j'ai mis quelque macro (Fichier A)

    Est ce possible que le fichier A(celui qui a les macro) puisse les exécuter au fichier B (fichier avec mes donnée?)

    Merci d'avance pour votre aide

  2. #2
    Membre émérite
    Homme Profil pro
    Retraité
    Inscrit en
    Octobre 2022
    Messages
    685
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Octobre 2022
    Messages : 685
    Par défaut
    Bonjour

    Est ce possible que le fichier A(celui qui a les macro) puisse les exécuter au fichier B (fichier avec mes donnée?)
    Il faut pour ça que les macros soient - un peu - étudiées pour et que le fichier A ouvre le fichier B, exécute ce qu'il a à faire, puis enregistre le fichier B (ou pas) et le ferme

    Dans le style

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    Option Explicit
     
    Sub toto()
    Dim MonBook as WorkBook
    Set MonBook = Workbooks.Open("C:\monEmplacement\FichierB.xls")
     
    ' ici ce que tu veux exécuter
     
    MonBook.Close Save:=true
     
    End Sub
    pas testé...

    Quand je dis que les macros appelées doivent être étudiées pour, il faut par exemple qu'elles ne contiennent pas de select, active et de références implicites

    Par exemple (de ce qu'il ne faut jamais faire )
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Sub Calcul()
    Dim W as long
    Sheets("NomDelaFeuille").Activate
    Range("A1").Select
    W = Selection.Value * 2
    Range("A2").Select 
    Selection.Value = W
    End Sub
    Pourra être réécrit en
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Sub Calcul(UnBook as WorkBook)
    With UnBook.Sheets("NomDelaFeuille")
        .Range("A2").Value = .Range("A1").Value * 2
    End With
    End Sub

  3. #3
    Membre actif
    Homme Profil pro
    Inscrit en
    Janvier 2012
    Messages
    18
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Janvier 2012
    Messages : 18
    Par défaut
    Bonjour,

    Voici ma macro que je voudrais pouvoir utiliser sur l'autre fichier.

    Mais j'ai un message d'erreur quand je l'exécute sur mon autre fichier(celui qui n'a pas de macro)

    Nom : Capture1.PNG
Affichages : 61
Taille : 5,2 Ko

    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
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
     
     
    Sub Traitement() 'Programme principal
        Call SupprimerColonnesSpecifiques
        Call SupprimerLignesSansDonneesColonneE
        Call RenommerEntetes
        Call TrierColonneE
        'Etc...
    End Sub
    Sub SupprimerColonnesSpecifiques()
        Dim ws As Worksheet
        Dim colonnesASupprimer As String
        Dim colonne As Variant
     
        ' Spécifie la feuille de travail
        Set ws = ThisWorkbook.Sheets("SALES") ' Remplacez "Feuille1" par le nom de votre feuille de travail
     
        ' Liste des colonnes à supprimer
        colonnesASupprimer = "A,C,D,E,F,G,H,I,J,K,L,M,N,O,P,R,U,V,W,Y,Z,AA"
     
        ' Divise la liste des colonnes à supprimer en un tableau
        Dim tableauColonnes As Variant
        tableauColonnes = Split(colonnesASupprimer, ",")
     
        ' Boucle à travers toutes les colonnes à partir de la dernière colonne
        For i = UBound(tableauColonnes) To 0 Step -1
            ' Vérifie si la colonne actuelle doit être supprimée
            On Error Resume Next
            ws.Columns(tableauColonnes(i)).Delete
            On Error GoTo 0
        Next i
    End Sub
     
    Sub RenommerEntetes()
        Dim ws As Worksheet
     
        ' Spécifie la feuille de travail
        Set ws = ThisWorkbook.Sheets("SALES") ' Remplacez "Feuille1" par le nom de votre feuille de travail
     
        ' Renomme les en-têtes des colonnes A à F
        ws.Cells(1, 1).Value = "N°DOSSIER"
        ws.Cells(1, 2).Value = "CAT TRANS"
        ws.Cells(1, 3).Value = "CLIENT"
        ws.Cells(1, 4).Value = "DATE UTILISATION"
        ws.Cells(1, 5).Value = "PLAQUE"
     
    End Sub
    Sub SupprimerLignesSansDonneesColonneE()
        Dim ws As Worksheet
        Dim lastRow As Long
        Dim i As Long
     
        ' Spécifie la feuille de travail
        Set ws = ThisWorkbook.Sheets("SALES") ' Remplacez "Feuille1" par le nom de votre feuille de travail
     
        ' Trouve la dernière ligne avec des données dans la colonne E
        lastRow = ws.Cells(ws.Rows.Count, "E").End(xlUp).Row
     
        ' Boucle à travers toutes les lignes de bas en haut
        For i = lastRow To 1 Step -1
            ' Vérifie si la cellule de la colonne E est vide
            If IsEmpty(ws.Cells(i, 5).Value) Then
                ' Supprime la ligne si la cellule est vide
                ws.Rows(i).Delete
            End If
        Next i
    End Sub
    Sub TrierColonneE()
        Dim ws As Worksheet
        Dim lastRow As Long
     
        ' Spécifie la feuille de travail
        Set ws = ThisWorkbook.Sheets("SALES") ' Remplacez "Feuille1" par le nom de votre feuille de travail
     
        ' Trouve la dernière ligne avec des données dans la colonne E
        lastRow = ws.Cells(ws.Rows.Count, "E").End(xlUp).Row
     
        ' Trie la colonne E
        ws.Range("E1:E" & lastRow).Sort key1:=ws.Range("E1"), order1:=xlAscending, Header:=xlYes
    End Sub

  4. #4
    Membre Expert
    Inscrit en
    Décembre 2002
    Messages
    993
    Détails du profil
    Informations forums :
    Inscription : Décembre 2002
    Messages : 993
    Par défaut
    Bonjour, puisque ton fichier B doit être mis à jour quotidiennement, pourquoi ne pas y intégrer les macros ?
    Je ne comprends pas l'utilité de développer tes macros dans un fichier, pour les exécuter dans un autre ???

  5. #5
    Membre actif
    Homme Profil pro
    Inscrit en
    Janvier 2012
    Messages
    18
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Janvier 2012
    Messages : 18
    Par défaut
    Citation Envoyé par Franc Voir le message
    Bonjour, puisque ton fichier B doit être mis à jour quotidiennement, pourquoi ne pas y intégrer les macros ?
    Je ne comprends pas l'utilité de développer tes macros dans un fichier, pour les exécuter dans un autre ???
    Bonjour, malheureusement c'est un fichier qui est exporté d'une application tiers et donc les macros s'efface a chaque fois

  6. #6
    Membre Expert
    Inscrit en
    Décembre 2002
    Messages
    993
    Détails du profil
    Informations forums :
    Inscription : Décembre 2002
    Messages : 993
    Par défaut
    Ok, je comprends mieux maintenant. Dans ce ces, les solutions proposées par Thumb down sont tout à fait adaptées.

  7. #7
    Membre Expert Avatar de Thumb down
    Homme Profil pro
    Retraité
    Inscrit en
    Juin 2019
    Messages
    1 580
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Juin 2019
    Messages : 1 580
    Par défaut
    Bonjour,
    ThisWorkbook est le classeur qui exécute la macro donc le classeur A.

    activeWorkbook me semble plus approprié.

    Tu à le choix entre un classeur xlam ou classeur type Perso.slb place dans le bon répertoire

Discussions similaires

  1. [XL-2016] Executer une macro sans l’arrêter et travailler sur d'autre fichier Excel
    Par KBrownie dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 24/01/2020, 10h47
  2. executer macro via une liste déroulante sur access
    Par RadioBerkane dans le forum VBA Access
    Réponses: 3
    Dernier message: 10/09/2012, 19h48
  3. [XL-2007] Executer macro sur un autre fichier
    Par jfdebutant dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 20/11/2009, 17h23
  4. Réponses: 10
    Dernier message: 28/08/2008, 09h15
  5. Execution macro lors d'une ouverture fichier excel
    Par fmris dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 23/10/2006, 12h00

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