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 :

comparer deux tableaux dans 2 fichiers differents [XL-2013]


Sujet :

Macros et VBA Excel

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2016
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Somme (Picardie)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2016
    Messages : 7
    Points : 7
    Points
    7
    Par défaut comparer deux tableaux dans 2 fichiers differents
    Bonjour,

    Je cherche a comparer 2 tableaux de structure identique dans 2 fichiers différents et si le tableau du fichier 1 a des lignes en plus on l'ajoute au tableau du fichier 2.
    Aujourd'hui j'utilise un système de double boucle et je compare la valeur de la case Ax ou je stock une valeur dont je me sert en "clé unique", mais c'est tres lourd. Avez vous des truc pour optimiser ca?

    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
    With Workbooks.Open(fichier1)
        'fichiersuivifnc.Sheet("Suivi des NC fournisseur").range("a1").Activate
        With .Worksheets("Suivi des NC fournisseur")
            .Cells.AutoFilter ' efface les filtre
            .Cells.AutoFilter ' le remet par défaut
            With .Sort
                .SortFields.Clear
                .SortFields.Add Key _
                :=Range("A2:A500"), SortOn:=xlSortOnValues, Order:=xlAscending, _
                DataOption:=xlSortNormal
                .SetRange Range("A1:AD346")
                .Header = xlYes
                .MatchCase = False
                .Orientation = xlTopToBottom
                .SortMethod = xlPinYin
                .Apply
            End With
     
     
            For j = 2 To .Range("A" & Rows.Count).End(xlUp).Row
                If .Range("a" & j).Value = "" Then GoTo suiviRQ
                For i = 2 To Fichierfnc.Worksheets("base externe").Range("A" & Rows.Count).End(xlUp).Row
                    'if Fichierfnc.Worksheets("base externe").Range("a" & i).Value=""
                    If Fichierfnc.Worksheets("base externe").Range("a" & i).Value = "" Or .Range("a" & j).Value = Fichierfnc.Worksheets("base externe").Range("a" & i).Value Then
                        Fichierfnc.Worksheets("base externe").Range("u" & i).Value = "oui"
                        Fichierfnc.Worksheets("base externe").Range("a" & i).Value = .Range("a" & j).Value
                        Fichierfnc.Worksheets("base externe").Range("b" & i).Value = .Range("f" & j).Value
                        Fichierfnc.Worksheets("base externe").Range("c" & i).Value = .Range("b" & j).Value
                        Fichierfnc.Worksheets("base externe").Range("d" & i).Value = .Range("e" & j).Value
                        Fichierfnc.Worksheets("base externe").Range("g" & i).Value = .Range("k" & j).Value
                        Fichierfnc.Worksheets("base externe").Range("h" & i).Value = .Range("j" & j).Value
                        Fichierfnc.Worksheets("base externe").Range("i" & i).Value = .Range("i" & j).Value
                        Fichierfnc.Worksheets("base externe").Range("j" & i).Value = .Range("l" & j).Value
                        Fichierfnc.Worksheets("base externe").Range("f" & i).Value = .Range("p" & j).Value
                        If Fichierfnc.Worksheets("base externe").Range("ah" & i).Value = "" Then
                            Fichierfnc.Worksheets("base externe").Range("ah" & i).Value = .Range("w" & j).Value
                            If .Range("a" & j).Hyperlinks.Count > 0 Then Fichierfnc.Worksheets("base externe").Range("ai" & i).Value = fichier1 & "\" & .Range("a" & j).Hyperlinks(1).Address
                        End If
                        GoTo suivantfnc
                    Else
                        'Fichierfnc.Worksheets("base externe").Range("u" & i).Value = "non"
                    End If
                Next i
    suivantfnc:
     
            Next j
     
     
     
    suiviRQ:
        End With
        .Close False
    End With

  2. #2
    Expert éminent sénior Avatar de Menhir
    Homme Profil pro
    Ingénieur
    Inscrit en
    Juin 2007
    Messages
    16 037
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2007
    Messages : 16 037
    Points : 32 866
    Points
    32 866
    Par défaut
    Citation Envoyé par hgmorse Voir le message
    Aujourd'hui j'utilise un système de double boucle et je compare la valeur de la case Ax ou je stock une valeur dont je me sert en "clé unique", mais c'est tres lourd. Avez vous des truc pour optimiser ca?
    Remplacer la seconde boucle par un Find.
    https://msdn.microsoft.com/fr-fr/lib.../ff839746.aspx

  3. #3
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2016
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Somme (Picardie)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2016
    Messages : 7
    Points : 7
    Points
    7
    Par défaut
    Merci Menhir, ca semble correspondre a ce que je cherchait, je vais voir si ca convient.

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

Discussions similaires

  1. Comparer deux valeurs dans fichiers textes.
    Par yellow29 dans le forum Débuter
    Réponses: 3
    Dernier message: 08/02/2015, 18h44
  2. Comparer deux lignes dans un fichier
    Par manouch95 dans le forum Général Java
    Réponses: 7
    Dernier message: 31/12/2014, 12h17
  3. [Toutes versions] Comparer plusieurs tableaux dans plusieurs fichiers word
    Par Respecting dans le forum Word
    Réponses: 1
    Dernier message: 14/12/2012, 22h17
  4. [Tableaux] stockage de tableaux dans un fichier
    Par solitaire dans le forum Langage
    Réponses: 4
    Dernier message: 25/12/2005, 15h34
  5. comparer deux tableaux
    Par djibril dans le forum Langage
    Réponses: 4
    Dernier message: 15/11/2005, 15h26

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