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 :

Comparaison tableau entre 2 feuilles [XL-2007]


Sujet :

Macros et VBA Excel

  1. #1
    Nouveau Candidat au Club
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Mai 2011
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux
    Secteur : Industrie

    Informations forums :
    Inscription : Mai 2011
    Messages : 6
    Points : 1
    Points
    1
    Par défaut Comparaison tableau entre 2 feuilles
    Bonjour,

    Voici mon problème, enfin plutôt la macro que je souhaiterais réaliser :

    J'ai un premier tableau dans une feuille appelée Produit et un autre tableau dans une autre feuille appelée Vente.
    Dans Produit, j'ai une colonne appelée code article, de même que dans vente.

    Je souhaiterais comparé les codes articles de la feuille Produit avec ceux de la feuille Vente. Si le code est retrouvé dans la feuille vente alors copier les 4 dernière colonnes et les coller à partir de la colonne K sur la ligne concernée par le produit dans la feuille Produit.

    J'espère être assez clair! Si quelqu'un peut m'aider, je lui en serais très reconnaissant!

    Merci d'avance

  2. #2
    Expert éminent Avatar de casefayere
    Homme Profil pro
    RETRAITE
    Inscrit en
    Décembre 2006
    Messages
    5 138
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : RETRAITE
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 138
    Points : 9 548
    Points
    9 548
    Par défaut
    Bonjour,

    Fait à main levée donc à adapter :
    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 essai()
    Dim art As Range, Wprod As Worksheet, Wvente As Worksheet
    derlg As Long, plageprod As Range, plageVente As Range, x As Long
    Set Wprod = Sheets("Produit")
    Set Wvente = Sheets("Vente")
    With Wvente
        derlg = .Range("A" & .Rows.Count).End(xlUp).Row 'derniere ligne feuille vente
        Set plageVente = .Range("A2:A" & derlg) 'si les codes sont en A
    End With
    With Wprod
        derlg = .Range("A" & .Rows.Count).End(xlUp).Row
        For x = 2 To derlg
            Set art = plageVente.Find(.Range("A" & x))
            If Not art Is Nothing Then
                .Range("K" & x, "n" & x) = Wvente.Range("K" & art.Row, "n" & art.Row) 'si les colonnes sont à partir de K
            End If
        Next x
    End With
    End Sub
    Cordialement,
    Dom
    _____________________________________________
    Vous êtes nouveau ? pour baliser votre code, cliquer sur cet exemple : Anomaly
    pensez à cliquer sur si votre problème l'est
    Par contre, il est désagréable de voir une discussion résolue sans message final du demandeur (satisfaction, désarroi, remerciement, conclusion...)

  3. #3
    Nouveau Candidat au Club
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Mai 2011
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux
    Secteur : Industrie

    Informations forums :
    Inscription : Mai 2011
    Messages : 6
    Points : 1
    Points
    1
    Par défaut
    Merci pour la macro proposé, cependant il me semble qu'il n'y a pas la partie pour copier les données?

  4. #4
    Expert éminent Avatar de casefayere
    Homme Profil pro
    RETRAITE
    Inscrit en
    Décembre 2006
    Messages
    5 138
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : RETRAITE
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 138
    Points : 9 548
    Points
    9 548
    Par défaut
    si, cette ligne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    .Range("K" & x, "n" & x) = Wvente.Range("K" & art.Row, "n" & art.Row)
    Cordialement,
    Dom
    _____________________________________________
    Vous êtes nouveau ? pour baliser votre code, cliquer sur cet exemple : Anomaly
    pensez à cliquer sur si votre problème l'est
    Par contre, il est désagréable de voir une discussion résolue sans message final du demandeur (satisfaction, désarroi, remerciement, conclusion...)

  5. #5
    Nouveau Candidat au Club
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Mai 2011
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux
    Secteur : Industrie

    Informations forums :
    Inscription : Mai 2011
    Messages : 6
    Points : 1
    Points
    1
    Par défaut
    D'accord!
    Alors mon adaptation ne doit pas être bonne!!
    Ma colonne article sur la feuille produit se trouve en D et sur l'autre feuille en A. Voici la macro que j'ai essayé :

    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
     
    Sub Test()
    Dim art As Range, Wprod As Worksheet, Wvente As Worksheet
    Dim plageprod As Range, derlg As Long, plageVente As Range, x As Long
    Set Wprod = Sheets("T375FIFF") 'produit
    Set Wvente = Sheets("pa") 'vente
    With Wvente
        derlg = .Range("A" & .Rows.Count).End(xlUp).Row 'derniere ligne feuille vente
        Set plageVente = .Range("A2:A" & derlg) 'si les codes sont en A
    End With
    With Wprod
        derlg = .Range("A" & .Rows.Count).End(xlUp).Row
        For x = 2 To derlg
            Set art = plageVente.Find(.Range("D" & x))
            If Not art Is Nothing Then
                .Range("K" & x, "n" & x) = Wvente.Range("K" & art.Row, "n" & art.Row) 'si les colonnes sont à partir de K
            End If
        Next x
    End With
    End Sub

  6. #6
    Expert éminent Avatar de casefayere
    Homme Profil pro
    RETRAITE
    Inscrit en
    Décembre 2006
    Messages
    5 138
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : RETRAITE
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 138
    Points : 9 548
    Points
    9 548
    Par défaut
    Attention à mes remarques dans ce code corrigé :

    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
    Sub Test()
    Dim art As Range, Wprod As Worksheet, Wvente As Worksheet
    Dim plageprod As Range, derlg As Long, plageVente As Range, x As Long
    Set Wprod = Sheets("T375FIFF") 'produit
    Set Wvente = Sheets("pa") 'vente
    With Wvente
        derlg = .Range("A" & .Rows.Count).End(xlUp).Row 'derniere ligne feuille vente
        Set plageVente = .Range("A2:A" & derlg) 'si les codes sont en A
    End With
    With Wprod
        derlg = .Range("D" & .Rows.Count).End(xlUp).Row 'ici j'ai changé A pour D
        For x = 2 To derlg
        Set art = plageVente.Find(.Range("D" & x))
        If Not art Is Nothing Then
            .Range("K" & x, "n" & x) = Wvente.Range("K" & art.Row, "n" & art.Row) 'si les colonnes sont à partir de K
        'attention ci-dessus, les données à copier sont'elles de K à N, dans la feuille "pa" ?
        End If
    Next x
    End With
    End Sub
    Cordialement,
    Dom
    _____________________________________________
    Vous êtes nouveau ? pour baliser votre code, cliquer sur cet exemple : Anomaly
    pensez à cliquer sur si votre problème l'est
    Par contre, il est désagréable de voir une discussion résolue sans message final du demandeur (satisfaction, désarroi, remerciement, conclusion...)

  7. #7
    Nouveau Candidat au Club
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Mai 2011
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux
    Secteur : Industrie

    Informations forums :
    Inscription : Mai 2011
    Messages : 6
    Points : 1
    Points
    1
    Par défaut
    Les données à copier sont de C à F sur la feuille "pa" et elles sont à coller en colonne K à N.

    J'aurai donc cette ligne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    If Not art Is Nothing Then
                .Range("K" & x, "n" & x) = Wvente.Range("C" & art.Row, "f" & art.Row) 'si les colonnes sont à partir de K
            End If

  8. #8
    Expert éminent Avatar de casefayere
    Homme Profil pro
    RETRAITE
    Inscrit en
    Décembre 2006
    Messages
    5 138
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : RETRAITE
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 138
    Points : 9 548
    Points
    9 548
    Par défaut
    Donc le problème est-il résolu, as-tu bien corrigé aussi cette ligne :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    With Wprod
        derlg = .Range("D" & .Rows.Count).End(xlUp).Row
    Cordialement,
    Dom
    _____________________________________________
    Vous êtes nouveau ? pour baliser votre code, cliquer sur cet exemple : Anomaly
    pensez à cliquer sur si votre problème l'est
    Par contre, il est désagréable de voir une discussion résolue sans message final du demandeur (satisfaction, désarroi, remerciement, conclusion...)

  9. #9
    Nouveau Candidat au Club
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Mai 2011
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux
    Secteur : Industrie

    Informations forums :
    Inscription : Mai 2011
    Messages : 6
    Points : 1
    Points
    1
    Par défaut
    Oui j'ai bien corrigé cette ligne mais cela ne copie rien sur ma feuille Produit.

    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 Test()
    Dim art As Range, Wprod As Worksheet, Wvente As Worksheet
    Dim plageprod As Range, derlg As Long, plageVente As Range, x As Long
    Set Wprod = Sheets("T375FIFF") 'produit
    Set Wvente = Sheets("pa") 'vente
    With Wvente
        derlg = .Range("A" & .Rows.Count).End(xlUp).Row 'derniere ligne feuille vente
        Set plageVente = .Range("A2:A" & derlg) 'si les codes sont en A
    End With
    With Wprod
        derlg = .Range("D" & .Rows.Count).End(xlUp).Row
        For x = 2 To derlg
            Set art = plageVente.Find(.Range("D" & x))
            If Not art Is Nothing Then
                .Range("K" & x, "n" & x) = Wvente.Range("C" & art.Row, "f" & art.Row) 'si les colonnes sont à partir de K
            End If
        Next x
    End With
    End Sub

  10. #10
    Expert éminent Avatar de casefayere
    Homme Profil pro
    RETRAITE
    Inscrit en
    Décembre 2006
    Messages
    5 138
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : RETRAITE
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 138
    Points : 9 548
    Points
    9 548
    Par défaut
    comme je ne peux pas tester moi-même, essaies en ajoutant ".value" :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    If Not art Is Nothing Then
       .Range("K" & x, "n" & x) = Wvente.Range("C" & art.Row, "f" & art.Row).Value
    End If
    Cordialement,
    Dom
    _____________________________________________
    Vous êtes nouveau ? pour baliser votre code, cliquer sur cet exemple : Anomaly
    pensez à cliquer sur si votre problème l'est
    Par contre, il est désagréable de voir une discussion résolue sans message final du demandeur (satisfaction, désarroi, remerciement, conclusion...)

  11. #11
    Nouveau Candidat au Club
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Mai 2011
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux
    Secteur : Industrie

    Informations forums :
    Inscription : Mai 2011
    Messages : 6
    Points : 1
    Points
    1
    Par défaut
    C'est ok. Ca fonctionne comme je le voulais. Merci bien

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

Discussions similaires

  1. [XL-2003] Comparaison données entre deux feuilles
    Par ivanG dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 30/05/2014, 09h51
  2. [XL-2007] Comparaison de données entre plusieurs feuilles d'un classeur
    Par Raphael39 dans le forum Excel
    Réponses: 8
    Dernier message: 02/07/2010, 22h54
  3. [XL-2003] Cellules fusionnées- comparaison entre 2 feuilles
    Par Nanoucha dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 25/08/2009, 14h39
  4. Réponses: 7
    Dernier message: 14/01/2008, 12h13
  5. copier/coller un tableau entre 2 feuilles
    Par kbakouan dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 09/07/2007, 21h49

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