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 :

Boucles et tableaux [XL-2010]


Sujet :

Macros et VBA Excel

  1. #1
    Membre averti
    Femme Profil pro
    Étudiant
    Inscrit en
    Mai 2013
    Messages
    34
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Mai 2013
    Messages : 34
    Par défaut Boucles et tableaux
    Bonjour a tous,

    Je suis actuellement sur un projet de stage et je bloque un peu...
    J'ai mis mon fichier excel en PJ et le code que j'ai ecrit pour l'instant ci dessous. Il doit y a voir une erreur dans une des declarations mais je ne trouve vraiment pas...
    Voila quelques explication supplementaires pour vous aider a comprendre mon projet. Pour chaque cellule du 2eme grand tableau bleu differente de "-" je teste d'abord le Q11 correspondant en le comparant aux valeurs reference de Q11 (dernier tableau orange) et je cree un tableau (virtuel seulement) qui recupere la liste de tous les profils compatibles. Je fais ensuite de meme avec n11 (la valeur inscite dans la cellule) et cree un autre tableau virtuel qui regroupe les profils possibles. L'idee est ensuite de comparer ces deux tableau et si un profil appartient au deux alors je veux inscrire sur ma feuille le profil, le D et le n qui correspondent.

    J'espere avoir ete assez claire, merci de votre aide!

    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
    Option Explicit
     
    Sub essai()
    Application.ScreenUpdating = False
    Application.Calculation = xlCalculationManual
     
    Dim lig As Long
    Dim col As Long
    Dim k As Long
    Dim l As Long
    Dim m As Long
    Dim n As Long
    Dim nombre As Long
     
    For lig = 37 To 63
        For col = 11 To 27
            If Cells(lig, col).Value <> "-" Then
            Dim tabl(500) As String
            Dim table(500) As String
     
                For k = 58 To 77
                    Dim nbr
                    If Cells(lig, 9).Value > Cells(k, 2) And Cells(lig, 9).Value < Cells(k, 4) Then
                        nbr = nbr + 1
                        tabl(nbr) = Cells(k, 1).Value
                    End If
                Next k
     
                For l = 36 To 55
                    Dim nbre
                    If Cells(lig, col).Value > Cells(l, 2) And Cells(lig, col).Value < Cells(l, 4) Then
                        nbre = nbre + 1
                        table(nbre) = Cells(l, 1).Value
                    End If
                Next l
     
                For m = 1 To 500
                    For n = 1 To 500
                        If tabl(m) = table(n) Then
                            nombre = nombre + 1
                            Cells(nombre, 5).Value = tabl(m)
                            Cells(nombre, 6).Value = Cells(lig, 10).Value
                            Cells(nombre, 7).Value = Cells(3, col).Value
                        End If
                    Next n
                Next m
     
            End If
        Next col
    Next lig
     
    Application.ScreenUpdating = True
    Application.Calculation = xlCalculationAutomatic
    End Sub
    Fichiers attachés Fichiers attachés

  2. #2
    Expert confirmé
    Homme Profil pro
    aucune
    Inscrit en
    Septembre 2011
    Messages
    8 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : aucune

    Informations forums :
    Inscription : Septembre 2011
    Messages : 8 208
    Par défaut
    Bonjour,

    Pourquoi dis-tu qu'il y a une erreur ?

  3. #3
    Expert confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2013
    Messages
    3 609
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Alimentation

    Informations forums :
    Inscription : Mai 2013
    Messages : 3 609
    Par défaut
    Une bonne habitude, selon moi, est de déclarer les variables en entête de procédure seulement...
    Et comme déjà dit, où et quelle est l'erreur ?

  4. #4
    Membre averti
    Femme Profil pro
    Étudiant
    Inscrit en
    Mai 2013
    Messages
    34
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Mai 2013
    Messages : 34
    Par défaut
    Lorsque je lance la macro, apres un temps (bien trop long soit disant passant), une erreur apparait. Aleatoirement j'ai soit une erreur 404 soit une erreur "Application-defined or object-defined error"
    D'habitude l'endroit qui bloque est surligne dans le code mais la rien n'est mis en evidence donc je ne trouve pas l'erreur...

  5. #5
    Expert confirmé
    Homme Profil pro
    aucune
    Inscrit en
    Septembre 2011
    Messages
    8 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : aucune

    Informations forums :
    Inscription : Septembre 2011
    Messages : 8 208
    Par défaut
    C'est cette boucle-ci qui fait que c'est long (250000 cycles à chaque passage) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
                For m = 1 To 500
                    For n = 1 To 500
                        If tabl(m) = table(n) Then
                            nombre = nombre + 1
                            Cells(nombre, 5).Value = tabl(m)
                            Cells(nombre, 6).Value = Cells(lig, 10).Value
                            Cells(nombre, 7).Value = Cells(3, col).Value
                        End If
                    Next n
                Next m
    Tu devrais pouvoir la remplacer par :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
                For m = 1 To 500
                    If tabl(m) <> "" Then
                        If IsNumeric(Application.Match(tabl(m), table, 0)) Then
                            nombre = nombre + 1
                            Cells(nombre, 5).Value = tabl(m)
                            Cells(nombre, 6).Value = Cells(lig, 10).Value
                            Cells(nombre, 7).Value = Cells(3, col).Value
                        End If
                    End If
                Next m


    et peut-être même sortir de la boucle si l'item de la table est vide.

  6. #6
    Membre averti
    Femme Profil pro
    Étudiant
    Inscrit en
    Mai 2013
    Messages
    34
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Mai 2013
    Messages : 34
    Par défaut
    Deja merci beaucoup pour cette reactivite!
    La solution proposee accelere enormement l'execution de la macro et il n'y a plus d'erreur!
    Neanmoins, aucune solution n'est retrounee! Rien ne s'ecrit sur ma feuille... Alors que je sais les solutions attendues...

  7. #7
    Expert confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2013
    Messages
    3 609
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Alimentation

    Informations forums :
    Inscription : Mai 2013
    Messages : 3 609
    Par défaut
    Est-ce que ceci te retournerait ce que tu attends ?


    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
    Sub essai()
        Dim lig As Long
        Dim col As Long
        Dim k As Long
        Dim l As Long
        Dim m As Long
        Dim n As Long
        Dim nombre As Long
        Dim tabl() As String
        Dim table() As String
        Dim nbr
        Dim nbre
     
        Application.ScreenUpdating = False
        Application.Calculation = xlCalculationManual
     
        For lig = 37 To 63
            For col = 11 To 27
                If Cells(lig, col).Value <> "-" Then
     
                    ReDim tabl(0)
                    ReDim table(0)
     
                    nbr = 0
                    For k = 58 To 77
                        If Cells(lig, 9).Value > Cells(k, 2) And Cells(lig, 9).Value < Cells(k, 4) Then
                            nbr = nbr + 1
                            ReDim Preserve tabl(nbr)
                            tabl(nbr) = Cells(k, 1).Value
                        End If
                    Next k
     
                    nbre = 0
                    For l = 36 To 55
                        If Cells(lig, col).Value > Cells(l, 2) And Cells(lig, col).Value < Cells(l, 4) Then
                            nbre = nbre + 1
                            ReDim Preserve table(nbre)
                            table(nbre) = Cells(l, 1).Value
                        End If
                    Next l
     
                    For m = 1 To UBound(tabl)
                        For n = 1 To UBound(table)
                            If tabl(m) = table(n) Then
                                nombre = nombre + 1
                                Cells(nombre, 5).Value = tabl(m)
                                Cells(nombre, 6).Value = Cells(lig, 10).Value
                                Cells(nombre, 7).Value = Cells(3, col).Value
                            End If
                        Next n
                    Next m
     
                End If
            Next col
        Next lig
     
        Application.ScreenUpdating = True
        Application.Calculation = xlCalculationAutomatic
     
        MsgBox "Terminé"
    End Sub

  8. #8
    Membre averti
    Femme Profil pro
    Étudiant
    Inscrit en
    Mai 2013
    Messages
    34
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Mai 2013
    Messages : 34
    Par défaut
    Malheureusement je n'ai toujorus rien qui s'affiche a la fin de la procedure alros que je sais qu'il y a des solutions...
    Je ne vois cependant pas ou est le pb!

  9. #9
    Expert confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2013
    Messages
    3 609
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Alimentation

    Informations forums :
    Inscription : Mai 2013
    Messages : 3 609
    Par défaut
    Je vois pourtant des données s'afficher dans les cellules E1 à G5.
    Mais ce n'est peut-être pas ce que tu veux afficher... (?)

  10. #10
    Membre averti
    Femme Profil pro
    Étudiant
    Inscrit en
    Mai 2013
    Messages
    34
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Mai 2013
    Messages : 34
    Par défaut
    Rien ne s'affiche de mon cote! c'est extremement frustrant...

  11. #11
    Membre averti
    Femme Profil pro
    Étudiant
    Inscrit en
    Mai 2013
    Messages
    34
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Mai 2013
    Messages : 34
    Par défaut
    Au temps pour moi, je n'avais pas place le code au bon endroit!
    La liste affichee me semble correcte!

    Mille merci pour votre aide inestimable!

  12. #12
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    13 169
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur, développeur et consultant Excel, Access, Word et VBA

    Informations forums :
    Inscription : Janvier 2010
    Messages : 13 169
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    Lorsque tu lances ta procédure, est-ce bien la feuille où se trouve tes données qui est active parce-que comme tu utilises l'objet Cells sans préciser les objets parents (workbook et worksheet) il est possible que tu lises des cellules vides.
    Philippe Tulliez
    Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément. (Nicolas Boileau)
    Lorsque vous avez la réponse à votre question, n'oubliez pas de cliquer sur et si celle-ci est pertinente pensez à voter
    Mes tutoriels : Utilisation de l'assistant « Insertion de fonction », Les filtres avancés ou élaborés dans Excel
    Mon dernier billet : Utilisation de la fonction Dir en VBA pour vérifier l'existence d'un fichier

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

Discussions similaires

  1. [Toutes versions] boucles et tableaux multidimensionnels dans excel vba
    Par chaudier37 dans le forum Excel
    Réponses: 1
    Dernier message: 24/01/2015, 12h43
  2. [FLASH MX2004 PRO] Boucle et tableaux
    Par guy2004 dans le forum Flash
    Réponses: 29
    Dernier message: 14/03/2006, 23h41
  3. [Tableaux] Problème avec les boucles
    Par speed_man002 dans le forum Langage
    Réponses: 4
    Dernier message: 21/09/2005, 15h42
  4. [Tableaux] Boucle while imbriquer
    Par Le-Cortex dans le forum Langage
    Réponses: 11
    Dernier message: 09/09/2005, 14h22
  5. Bug boucles et tableaux
    Par sebduth dans le forum Fortran
    Réponses: 3
    Dernier message: 31/05/2005, 13h49

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