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 :

Optimisation code insertion ligne dans tableau


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Architecte technique
    Inscrit en
    Juillet 2018
    Messages
    24
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 65
    Localisation : Belgique

    Informations professionnelles :
    Activité : Architecte technique
    Secteur : Enseignement

    Informations forums :
    Inscription : Juillet 2018
    Messages : 24
    Par défaut Optimisation code insertion ligne dans tableau
    Bonjour,
    J'ai besoin d'un peu d'aide pour mon code VBA puis-je compter sur vous ?

    J'ai écrit le code suivant :
    Sélection de lignes d'un tableau structuré "import" dans la feuille "import" d mon classeur
    si une certaine valeur ("NE") est trouvée dans la colonne "Check" du tableau alors insérer un nouvelle ligne dans le tableau "lstcoles" de la feuille "Ecole" du même classeur avec les valeurs de plusieurs colonnes du tableau "import" et ce pour toutes les lignes du tableau "import"
    Situation de base :
    tableau lstecole contient 1055 lignes
    Tableau import contient 244 ligne dont 241 à insérer dans lstecole.
    Le code fonctionne bien mais il faut 30 minute pour l'exécuter. Alors si vous avez une idée pour optimiser…
    Je vous remercie d'avance.



    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
    Private Sub CommandButton1_Click()
     
    Dim nbr As Integer
    Dim row As Range
    Dim tabl As ListObject
    Dim i As Long
    Dim ccheck As Long, cecole As Integer, cville As Integer, cadresse As Integer, ccp As Integer, ctel As Integer, ccontact As Integer, cemail As Integer
    Dim vcheck As String, vecole As String, vville As String, vadresse As String, vcp As String, vtel As String, vcontact As String, vemail As String
     
     
    Set tabl = ActiveSheet.ListObjects("import")
     With tabl.ListColumns("check")
      ccheck = .Index
      End With
     With tabl.ListColumns("Nom de l'établissement")
      cecole = .Index
      End With
      With tabl.ListColumns("Adresse où les animations doivent avoir lieu: (Adresse postale)")
      cadresse = .Index
      End With
      With tabl.ListColumns("Adresse où les animations doivent avoir lieu: (Ville)")
      cville = .Index
      End With
      With tabl.ListColumns("Adresse où les animations doivent avoir lieu: (ZIP / Code postal)")
      ccp = .Index
      End With
      With tabl.ListColumns("N° de Téléphone de contact:")
      ctel = .Index
      End With
      With tabl.ListColumns("Responsable")
      ccontact = .Index
      End With
      With tabl.ListColumns("adresse E-mail :")
      cemail = .Index
      End With
     
    nbr = Range("import").Rows.Count
    MsgBox nbr
     
    i = 0
    For Each row In Range("import").Rows
    i = i + 1
    If i < 2 Then
     
      If Range("Import").Cells(i, ccheck) = "NEW" Then
        'MsgBox i & " " & Range("Import").Cells(i, ccheck)
          vecole = Range("Import").Cells(i, cecole)
          vville = Range("Import").Cells(i, cville)
          vadresse = Range("Import").Cells(i, cadresse)
          vcp = Range("Import").Cells(i, ccp)
          vtel = Range("Import").Cells(i, ctel)
          vcontact = Range("Import").Cells(i, ccontact)
          vemail = Range("Import").Cells(i, cemail)
     '---------------------------------------------------------------------------------
     'Insertion nouvelle ecole
     '---------------------------------------------------------------------------------
     
    Sheets("ecole").ListObjects("lstecoles").Range.AutoFilter Field:=2 'suppression du filtre
    Sheets("ecole").ListObjects("lstecoles").ListRows(nbr + 1).Range.Insert xlShiftDown 'insertion  ligne
     
     With Sheets("ecole")
     .Range("B2").Value = vecole
     .Range("c2").Value = vadresse
     .Range("d2").Value = vcp
     .Range("e2").Value = vville
     .Range("f2").Value = vtel
     .Range("h2").Value = vcontact
     .Range("i2").Value = vemail
     
     End With
    End If
     End If
     
    Next row
    End Sub

  2. #2
    Expert confirmé
    Homme Profil pro
    Responsable des études
    Inscrit en
    Juillet 2014
    Messages
    2 680
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Aude (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Responsable des études
    Secteur : Santé

    Informations forums :
    Inscription : Juillet 2014
    Messages : 2 680
    Par défaut
    Bonjour,

    Merci d'utiliser les balises codes (bouton #)

    si une certaine valeur ("NE") est trouvée dans la colonne "Check" du tableau alors insérer un nouvelle ligne dans le tableau "lstcoles" de la feuille "Ecole" du même classeur avec les valeurs de plusieurs colonnes du tableau "import" et ce pour toutes les lignes du tableau "import"
    Bien plus rapide qu'une boucle, je te conseille l'utilisation des filtres avancées: https://philippetulliez.developpez.c...dvancedfilter/

  3. #3
    Membre averti
    Homme Profil pro
    Architecte technique
    Inscrit en
    Juillet 2018
    Messages
    24
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 65
    Localisation : Belgique

    Informations professionnelles :
    Activité : Architecte technique
    Secteur : Enseignement

    Informations forums :
    Inscription : Juillet 2018
    Messages : 24
    Par défaut
    Merci Halaster08
    Mais ce n'est pas la lecture qui prend du temps c'est l'insertion des lignes dans l'autre tableau.

    Maintenant si tu as une solution avec les filtres, je suis preneur.

    Merci d'avance

  4. #4
    Expert confirmé
    Homme Profil pro
    Responsable des études
    Inscrit en
    Juillet 2014
    Messages
    2 680
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Aude (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Responsable des études
    Secteur : Santé

    Informations forums :
    Inscription : Juillet 2014
    Messages : 2 680
    Par défaut
    Citation Envoyé par Pabri Voir le message
    Maintenant si tu as une solution avec les filtres, je suis preneur.
    Oui dans le tuto que j'ai linké
    Le filtre avancé permet d'envoyer le résultat du filtre sur une autre feuille, exactement ce que tu cherches a faire si j'ai bien compris.

  5. #5
    Membre averti
    Homme Profil pro
    Architecte technique
    Inscrit en
    Juillet 2018
    Messages
    24
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 65
    Localisation : Belgique

    Informations professionnelles :
    Activité : Architecte technique
    Secteur : Enseignement

    Informations forums :
    Inscription : Juillet 2018
    Messages : 24
    Par défaut
    Bonjour Halaster08,

    Cette solution est géniale, mon petit problème c'est que je doit insérer les données filtrées dans un autre tableau structuré sur une autre feuille. Tableau dans lequel il y a déjà des données.
    Deuxième petit problème, le nom des colonnes qui doit être identique.
    Donc voila je cherche toujours une solution

    Merci encore.

  6. #6
    Expert confirmé
    Homme Profil pro
    Responsable des études
    Inscrit en
    Juillet 2014
    Messages
    2 680
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Aude (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Responsable des études
    Secteur : Santé

    Informations forums :
    Inscription : Juillet 2014
    Messages : 2 680
    Par défaut
    Citation Envoyé par Pabri Voir le message
    le nom des colonnes qui doit être identique.
    Pour le filtre avancé aussi.
    Dans le troisième paramètre du filtre (celui qui demande où tu envoie tes données), si la plage contient du texte alors il ne prendra que les colonnes dont les noms seront identique à ceux de cette plage

    Citation Envoyé par Pabri Voir le message
    Tableau dans lequel il y a déjà des données.
    Tu peux recopier la ligne des titres en bas du tableau, faire le filtre avancé puis supprimer la ligne de titre

Discussions similaires

  1. Excel 2016 BUG ? insert ligne dans un tableau
    Par Pabri dans le forum Excel
    Réponses: 2
    Dernier message: 27/09/2018, 00h24
  2. [XL-2007] Insertion ligne dans un tableau (ListObject) sur feuille protégée
    Par Damran dans le forum Conception
    Réponses: 4
    Dernier message: 22/08/2012, 16h32
  3. [XL-2007] Insertion ligne dans un tableau par rapport à un fichier d'origine
    Par XceSs dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 13/01/2011, 14h05
  4. [WD-2003] Insertion automatique de ligne dans tableau word après renvoi à la ligne
    Par melouille56 dans le forum VBA Word
    Réponses: 5
    Dernier message: 05/08/2009, 15h49
  5. Insertion javascript dans tableau HTML
    Par Rocca dans le forum Général JavaScript
    Réponses: 5
    Dernier message: 08/08/2005, 12h28

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