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

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  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...

+ 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