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

VBA Access Discussion :

Comprendre les paramètres Optional dans une procédure ou une fonction [AC-2016]


Sujet :

VBA Access

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    1 895
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2007
    Messages : 1 895
    Par défaut Comprendre les paramètres Optional dans une procédure ou une fonction
    Bonjour,

    Dans les paramètres d'une fonction, j'ai mis un paramètre optionnel

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Optional Hors_Budget As Boolean
    Je pensai ainsi traiter 3 cas : Vrai, Faux ou null

    Je ne comprends pas : Si le paramètre optionnel n'est renseigné, la fonction considère que Hors_Budget=Faux

    Il faux donc un autre format que Boolean pour avoir ce que je voudrais ?

    Merci pour votre aide

  2. #2
    Expert confirmé

    Homme Profil pro
    consultant développeur
    Inscrit en
    Mai 2005
    Messages
    3 048
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : consultant développeur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 048
    Par défaut
    Bonjour,
    Si tu veux passer NULL alors il faut déclarer : Hors_Budget as Variant

    Cdlt

  3. #3
    Membre éprouvé
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    1 895
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2007
    Messages : 1 895
    Par défaut
    Merci

    Cela marche

    mais du coup le test qui suit n'est plus IsNull mais IsError et dans le code qui suit

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    Select Case Hors_Budget
       Case "Vrai"
       Case "Faux"
       Case Else
    End Select
    au lieu de

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    Select Case Hors_Budget
       Case True
       Case False
       Case Else
    End Select

    L'essentiel est que cela marche.

    Merci

  4. #4
    Expert confirmé

    Homme Profil pro
    consultant développeur
    Inscrit en
    Mai 2005
    Messages
    3 048
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : consultant développeur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 048
    Par défaut
    Pour éviter isError, on peut écrire ta procedure ainsi :
    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
     
       sub  fonctionTest(Optional Hors_Budget As variant)
     
       if isnull(Hors_Budget) then
        ....
      else
          if Hors_Budget = -1 then
          ' VRAI
             ....
          elseif Hors_Budget = 0 then
           ' FAUX
           else
            ' PAS POSSIBLE
            end if
     
       end if 
     
    end sub
    cdlt

  5. #5
    Invité
    Invité(e)
    Par défaut
    Bonsoir ,
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    function MyFonction(Optional Hors_Budget As integer = -1)
    Select case Hors_Budget
              case -1 'null
              case 0 'false
              case 1 'true
    End select

  6. #6
    Membre éprouvé
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    1 895
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2007
    Messages : 1 895
    Par défaut
    Citation Envoyé par dysorthographie Voir le message
    Bonsoir ,
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    function MyFonction(Optional Hors_Budget As integer = -1)
    Select case Hors_Budget
              case -1 'null
              case 0 'false
              case 1 'true
    End select
    merci mais je n'arrive pas au même résultat pour le 3ème cas

    MyFonction(true) donne -1 pour Hors_Budget et pas +1

    J'ai bien -1 avec MyFonction() et 0 avec MyFonction(false)

  7. #7
    Invité
    Invité(e)
    Par défaut
    Bonsoir,
    Ok
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    function MyFonction(Optional Hors_Budget As integer = 2)
    Select case Hors_Budget
              case -1 'true
              case 0 'false
              case else 'null
    End select

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

Discussions similaires

  1. [JVM][OPTIONS][OPTIMISATION]pc dédié à Java
    Par narmataru dans le forum Général Java
    Réponses: 7
    Dernier message: 16/04/2003, 18h12
  2. [Kylix] kylix3 : pb sur options de projet
    Par Arsene dans le forum EDI
    Réponses: 3
    Dernier message: 09/04/2003, 11h41
  3. [propriétés]Option Checked
    Par psl dans le forum Composants VCL
    Réponses: 6
    Dernier message: 22/08/2002, 09h07
  4. Parametrage des options de projet
    Par ares7 dans le forum EDI
    Réponses: 7
    Dernier message: 22/07/2002, 16h33
  5. Vous gerez comment les options d'un programme?
    Par n0n0 dans le forum C++Builder
    Réponses: 5
    Dernier message: 17/05/2002, 14h21

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