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 :

Ajouter une ligne à un tableau, VBA


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2014
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2014
    Messages : 4
    Par défaut Ajouter une ligne à un tableau, VBA
    Bonjour à tous,

    J'ai développé à l'aide d'exemples un code sous cette forme:

    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
    DerLig1 = Worksheets("Livraison à venir").Range("A" & Rows.Count).End(xlUp).Row
    DerLig2 = Worksheets("Matrice F-DOC").Range("A" & Rows.Count).End(xlUp).Row
    TabIni1 = Worksheets("Livraison à venir").Range("A3:K" & DerLig1)
    TabRef1 = Worksheets("Matrice F-DOC").Range("A3:K" & DerLig2)
    
    For k = LBound(TabRef1) To UBound(TabRef1)
    For l = LBound(TabIni1) To UBound(TabIni1)
    If TabRef1(k, 1) = TabIni1(l, 1) Then
    
    If TabRef1(k, 2) = TabIni1(l, 2) Then
    Rows("k:k").Select
    Selection.Insert Shift:=xlDown, CopyOrigin:=xlFormatFromLeftOrAbove
    k = k + 1
    TabRef1(k, 1) = TabRef1(k - 1, 1)
    End If
    
    TabIni1(l, 2) = TabRef1(k, 2)
    TabIni1(l, 3) = TabRef1(k, 3)
    TabIni1(l, 4) = TabRef1(k, 4)
    TabIni1(l, 5) = TabRef1(k, 5)
    TabIni1(l, 6) = TabRef1(k, 6)
    TabIni1(l, 7) = TabRef1(k, 7)
    TabIni1(l, 8) = TabRef1(k, 8)
    
    
    
    Exit For
    End If
    Next
    Next
    
    Worksheets("Livraison à venir").Range("A3").Resize(UBound(TabIni1, 1), UBound(TabIni1, 2)) = TabIni1
    Il s'agit d'une simple comparaison et import de données d'une feuille à une autre, le point particulier reviens à ajouter une ligne lorsque la donnée de référence est présente en de multiples versions dans la feuille de référence.
    Cependant, la partie rouge ne fonctionne pas (je m'y attendais un peut en même temps..), elle correspond au saut de ligne que je n'arrive pas a traiter sous cette forme de code.

    J'ai ajouté un exemple remanié pour illustrer mon problème.
    Concrètement, j'aimerais importer des données de la Feuil1 vers la Feuil2 pour obtenir le résultat en Feuil3.
    Cependant, je bloque sur le cas particulier des documents multiples ou j'aimerais rajouter des lignes à mon fichier selon le nombre de version de ce document.

    L'un d'entre vous connaitrais-t-il une solution à mon problème?

    Classeur3.xlsm

    Merci à vous!

  2. #2
    Nouveau candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Juillet 2015
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juillet 2015
    Messages : 2
    Par défaut
    Salut

    Petite erreur de syntaxe il me semble : essaie avec ca
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     Rows(k & ":" & k).Select

  3. #3
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2014
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2014
    Messages : 4
    Par défaut
    Bonjour Lesaintnuage,

    Effectivement, il y avait une erreur de syntaxe. Avec la modification apportée le code se lance, mais n'effectue pas le retour à la ligne lorsqu'il le devrait..
    Du coup mon code n'est pas vraiment au point. J'ai apporté une modification supplémentaire sous cette forme car je pense que la dernière n'était pas bonne:

    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
    Sub Macro1()
     
     
    DerLig1 = Worksheets("Livraison à venir").Range("A" & Rows.Count).End(xlUp).Row
    DerLig2 = Worksheets("Matrice F-DOC").Range("A" & Rows.Count).End(xlUp).Row
    TabIni1 = Worksheets("Livraison à venir").Range("A3:K" & DerLig1)
    TabRef1 = Worksheets("Matrice F-DOC").Range("A3:K" & DerLig2)
     
    For k = LBound(TabRef1) To UBound(TabRef1)
    For l = LBound(TabIni1) To UBound(TabIni1)
     
    If TabRef1(k, 1) = TabIni1(l, 1) Then
     
     
    TabIni1(l, 2) = TabRef1(k, 2)
    TabIni1(l, 3) = TabRef1(k, 3)
    TabIni1(l, 4) = TabRef1(k, 4)
    TabIni1(l, 5) = TabRef1(k, 5)
    TabIni1(l, 6) = TabRef1(k, 6)
    TabIni1(l, 7) = TabRef1(k, 7)
    TabIni1(l, 8) = TabRef1(k, 8)
     
    If TabRef1(k, 1) = TabIni1(l + 1, 1) Then
    Rows(k & ":" & k).Select
    Selection.Insert Shift:=xlDown, CopyOrigin:=xlFormatFromLeftOrAbove
    k = k + 1
    l = l + 1
    TabRef1(k, 1) = TabRef1(k - 1, 1)
    End If
     
    TabIni1(l, 2) = TabRef1(k, 2)
    TabIni1(l, 3) = TabRef1(k, 3)
    TabIni1(l, 4) = TabRef1(k, 4)
    TabIni1(l, 5) = TabRef1(k, 5)
    TabIni1(l, 6) = TabRef1(k, 6)
    TabIni1(l, 7) = TabRef1(k, 7)
    TabIni1(l, 8) = TabRef1(k, 8)
     
     
    Exit For
    End If
    Next
    Next
     
    Worksheets("Livraison à venir").Range("A3").Resize(UBound(TabIni1, 1), UBound(TabIni1, 2)) = TabIni1
     
     
    End Sub

    Mais cela ne fonctionne pas, je ne suis pas certain de suivre la bonne logique d'utilisation des tableaux vba sur ce coup.

Discussions similaires

  1. Ajouter une ligne à un tableau (adaptation d'un script existant)
    Par beegees dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 26/10/2008, 11h04
  2. Réponses: 8
    Dernier message: 21/10/2008, 10h15
  3. [DOM] Ajouter une ligne à un tableau
    Par Arnard dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 13/04/2007, 09h59
  4. Ajouter une ligne à un tableau
    Par frog43 dans le forum Général JavaScript
    Réponses: 7
    Dernier message: 19/03/2007, 14h39
  5. Ajouter une ligne à un tableau
    Par Oluha dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 16/02/2005, 15h20

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