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

Access Discussion :

[VBA] Envoyer un listBox en paramètre à une fonction


Sujet :

Access

  1. #1
    Membre régulier
    Profil pro
    Étudiant
    Inscrit en
    Février 2006
    Messages
    126
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : Canada

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2006
    Messages : 126
    Points : 108
    Points
    108
    Par défaut [VBA] Envoyer un listBox en paramètre à une fonction
    Bonjour à tous
    Je veux envoyer un listbox à une fonction.

    Je fais comme ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    creerTableauExcel anneeDebut, anneeFin, moisDebut, moisFin, numeroTYPEDONNEE, _
                    Me!lstSh810, Me!lstProvinces, Me!lstPays, Me!CocherTousProvinces.Value, _
                    Me!CocherTousPays.Value
    Ceci a fonctionné et j'ai même utilisé le listbox "lstSh810" à l'intérieur de ma fonction.

    Et un moment donnée. Ça a affiché le message suivant : "Utilisation incorect de null".
    Bien entendu le listbox ayant le nom lstSh810 existe réellement alors il ne doit pas être null.

    Quelqu'un comprend l'erreur???

    Mary

  2. #2
    Expert éminent sénior
    Avatar de Dolphy35
    Homme Profil pro
    Responsable Systemes d'Information
    Inscrit en
    Octobre 2004
    Messages
    4 373
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Responsable Systemes d'Information
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2004
    Messages : 4 373
    Points : 11 218
    Points
    11 218
    Par défaut
    Salut,

    et le débogueur s'arrête où ? Tous tes paramètres ont-ils une valeurs ?

    Sinon montre nous ta fonction.

  3. #3
    Membre régulier
    Profil pro
    Étudiant
    Inscrit en
    Février 2006
    Messages
    126
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : Canada

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2006
    Messages : 126
    Points : 108
    Points
    108
    Par défaut
    Le débugger s'arrête sur la ligne que j'ai affiché, l'appel de la fonction creerFichierExcel

    anneeDebut = "1996"
    anneeFin = "2005"
    moisDebut = ""
    moisFin = ""
    numeroTYPEDONNEE = 2
    Me.lstSh810 = Null
    Me.lstProvinces = Null
    Me.lstPays = Null
    CocherTousProvince = 0
    CocherTousPays = 0

  4. #4
    Responsable Access

    Avatar de Arkham46
    Profil pro
    Inscrit en
    Septembre 2003
    Messages
    5 865
    Détails du profil
    Informations personnelles :
    Localisation : France, Loiret (Centre)

    Informations forums :
    Inscription : Septembre 2003
    Messages : 5 865
    Points : 14 524
    Points
    14 524
    Par défaut Re: [VBA] Envoyer un listBox en paramètre à une fonction
    slt,

    Citation Envoyé par kissmytoe
    le listbox ayant le nom lstSh810 existe réellement alors il ne doit pas être null.
    c'est pas le contrôle qui est null, c'est sa valeur

    à tester au préalable avec IsNull ou utiliser la fonction Nz pour transformer le Null en chaîne vide

  5. #5
    Expert éminent sénior
    Avatar de Dolphy35
    Homme Profil pro
    Responsable Systemes d'Information
    Inscrit en
    Octobre 2004
    Messages
    4 373
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Responsable Systemes d'Information
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2004
    Messages : 4 373
    Points : 11 218
    Points
    11 218
    Par défaut
    re,

    tu peux mettre ta fonction, stp.

  6. #6
    Membre régulier
    Profil pro
    Étudiant
    Inscrit en
    Février 2006
    Messages
    126
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : Canada

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2006
    Messages : 126
    Points : 108
    Points
    108
    Par défaut
    Ca change rien de mettre ma fonction.
    Il n'entre jamais dans ma fonction.

    Lorsqu'il j'essai de l'appelé ca plante tout simplement.

    Je peux toujours te mettre l'en-tête de la fonction si tu veux.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Function creerTableauExcel(ByVal anneeDebut As String, ByVal anneeFin As String, ByVal moisDebut As String, ByVal moisFin As String, _
                             ByVal numeroTYPEDONNEE As Integer, ByRef listSH810 As listBox, ByRef listProvinces As listBox, ByRef listPays As listBox, ByVal tousProvinces As Boolean, ByVal tousPays As Boolean)

  7. #7
    Responsable Access

    Avatar de Arkham46
    Profil pro
    Inscrit en
    Septembre 2003
    Messages
    5 865
    Détails du profil
    Informations personnelles :
    Localisation : France, Loiret (Centre)

    Informations forums :
    Inscription : Septembre 2003
    Messages : 5 865
    Points : 14 524
    Points
    14 524
    Par défaut
    alors pour passer l'objet contrôle met un point à la place du point d'exclamation

    le point d'exclamation c'est pour travailler sur le recordset du formulaire, donc c'est le champ de la source qui est renvoyé, pas le contrôle

  8. #8
    Membre émérite

    Profil pro
    Inscrit en
    Février 2005
    Messages
    1 751
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 1 751
    Points : 2 368
    Points
    2 368
    Par défaut Re: [VBA] Envoyer un listBox en paramètre à une fonction
    Bonjour le Québec (ça fait plaisir ),

    {EDIT} Ce qui suit n'est pas une solution au Pb évoqué.
    Néanmoins, je suggère quand même d'éviter de typer les paramètres d'une fonction quand les valeurs de paramètres sont directement obtenues à partir de la propriété Value d'un contrôle, afin de "tolérer" une valeur Null toujours possible.{/EDIT}

    Le Pb présenté me rappelle certains soucis.
    Qu'est-ce qui te fait croire que le contrôle ListBox est à l'origine de l'erreur "Utilisation incorrecte de Null" ?
    Citation Envoyé par kissmytoe
    Ceci a fonctionné et j'ai même utilisé le listbox "lstSh810" à l'intérieur de ma fonction.

    Et un moment donnée. Ça a affiché le message suivant : "Utilisation incorect de null".
    Bien entendu le listbox ayant le nom lstSh810 existe réellement alors il ne doit pas être null.
    En fait, d'après mon expérience, le Pb vient plutôt du typage des paramètres de la fonction qui se révèlent incompatibles avec le formulaire qui contient les contrôles, quand la source de données de ce formulaire est vide (ou encore à l'ouverture du formulaire, avant le chargement des données).
    En effet, dans le cas d'une source de données vide, l'expression Me!CocherTousProvinces.Value retourne Null, ce qui est incompatible avec le type Boolean.

    Aussi je te suggère, en ce qui concerne les valeurs de paramètres directement obtenues à partir des contrôles, d'utiliser plutôt un type Variant au lieu de Boolean.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Function creerTableauExcel(ByVal anneeDebut As String, ByVal anneeFin As String, _
                ByVal moisDebut As String, ByVal moisFin As String, _
                ByVal numeroTYPEDONNEE As Integer, ByRef listSH810 As listBox, _
                ByRef listProvinces As listBox, ByRef listPays As listBox, _
                ByVal tousProvinces As Variant, ByVal tousPays As Variant)
    Dans le corps de la fonction, si le paramètre de fonction tousProvinces vaut Null, alors tu sais qu'il faut ignorer l'appel à la fonction (Exit Function).

    D'une façon générale, contrôle le type des données passées en paramètres de la focntion.

  9. #9
    Membre régulier
    Profil pro
    Étudiant
    Inscrit en
    Février 2006
    Messages
    126
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : Canada

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2006
    Messages : 126
    Points : 108
    Points
    108
    Par défaut
    alors pour passer l'objet contrôle met un point à la place du point d'exclamation

    le point d'exclamation c'est pour travailler sur le recordset du formulaire, donc c'est le champ de la source qui est renvoyé, pas le contrôle
    Merci infiniment Tout fonctionne maintenant

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

Discussions similaires

  1. Réponses: 12
    Dernier message: 04/04/2007, 09h41
  2. Envoyer un paramètre à une fonction.
    Par Squalthor dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 12/10/2006, 17h40
  3. [PL/SQL] : Passage de paramètres à une fonction
    Par dcollart dans le forum Oracle
    Réponses: 5
    Dernier message: 13/07/2006, 10h17
  4. [VBA-A]procédure avec comme paramètre une propriété
    Par eultartuffe dans le forum VBA Access
    Réponses: 2
    Dernier message: 24/04/2006, 13h49
  5. [VBA-E] Lister les arguments d'une fonction
    Par laloune dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 26/02/2006, 12h04

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