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 :

Problème de parametre fonction : tableau d'entier


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Étudiant
    Inscrit en
    Octobre 2008
    Messages
    69
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2008
    Messages : 69
    Par défaut Problème de parametre fonction : tableau d'entier
    Bonjour,

    J'ai un petit problème de type avec une fonction mais je ne vois pas d'où cela peut venir.

    Voilà le code vba (épuré des éléments inutiles):

    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
    Sub Macro1()
     
        'Déclaration des variables
        Dim tb_gravite3() As Integer
     
        'Redimension des tableaux en fonction de la longueur de la feuille 1
        numligne = Range("A65536").End(xlUp).Row
        ReDim tb_gravite3(numligne)
     
        MsgBox NbElement(tb_gravite3)
     
    End Sub
     
    Function NbElement(ByRef Tableau() As Integer) As Integer
     
        Dim i, resultat As Integer
        Dim trouve As Boolean
        trouve = False
     
        Do While i <= UBound(Tableau) And Not trouve
            If Tableau(i) = Null Then
                resultat = i
                trouve = True
            End If
        Next i
     
        NbElement = resultat
     
    End Function
    Merci à vous.

  2. #2
    Membre averti
    Inscrit en
    Novembre 2008
    Messages
    20
    Détails du profil
    Informations forums :
    Inscription : Novembre 2008
    Messages : 20
    Par défaut
    Salut,

    Tu as peut-être un peu trop épuré ton code... Du coup il fonctionne bien lorsque l'on corrige les fautes de recopie et qu'on le colle dans un excel vide :

    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
     
    Sub Macro1()
     
        'Déclaration des variables
        Dim tb_gravite3() As Integer
     
        'Redimension des tableaux en fonction de la longueur de la feuille 1
        numligne = Range("A65536").End(xlUp).Row
        ReDim tb_gravite3(numligne)
     
        MsgBox NbElement(tb_gravite3)
     
    End Sub
     
    Function NbElement(ByRef Tableau() As Integer) As Integer
     
        Dim i, resultat As Integer
        Dim trouve As Boolean
        trouve = False
     
        Do While i <= UBound(Tableau) And Not trouve
            If Tableau(i) = 0 Then
                resultat = i
                trouve = True
            End If
            i = i + 1 'Sinon on boucle indéfiniment !!!
        Loop 'ET PAS NEXT !!!
     
        NbElement = resultat
     
    End Function
    Essaie de nous mettre plus de détails... L'erreur de type apparait à quel endroit lorsque tu execute en pas-à-pas ?

Discussions similaires

  1. Réponses: 11
    Dernier message: 14/10/2006, 21h26
  2. Réponses: 6
    Dernier message: 22/09/2006, 18h17
  3. Réponses: 13
    Dernier message: 13/10/2005, 16h03
  4. Réponses: 3
    Dernier message: 05/10/2005, 17h26
  5. [LG]Parametres ou resultat de fonction : tableau
    Par patdez dans le forum Langage
    Réponses: 2
    Dernier message: 12/05/2004, 12h19

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