4D v16.3

Choisir

Accueil

 
4D v16.3
Choisir

Choisir 


 

Choisir ( critère ; valeur {; valeur2 ; ... ; valeurN} ) -> Résultat 
Paramètre Type   Description
critère  Booléen, Entier in Valeur à tester
valeur  Expression in Valeurs possibles
Résultat  Expression in Valeur de critère

La commande Choisir retourne l’une des valeurs passées dans les paramètres valeur, valeur2, etc. en fonction de la valeur du paramètre critère.

Vous pouvez passer un paramètre critère de type booléen ou numérique :

  • Si critère est un booléen, Choisir retourne valeur si le booléen vaut Vrai et valeur2 si le booléen vaut Faux. Dans ce cas, la commande attend exactement trois paramètres : critère, valeur et valeur2.
  • Si critère est un entier, Choisir retourne la valeur dont la position correspond à critère. Attention, la numérotation des valeurs débute à 0 (la position de valeur est 0). Dans ce cas, la commande attend au minimum deux paramètres : critère et valeur.

La commande accepte tous les types de données pour le(s) paramètre(s) valeur, hormis les images, pointeurs, BLOBS et tableaux. Veillez cependant à ce que toutes les valeurs passées soient du même type, 4D n’effectue pas de vérification sur ce point.

Si aucune valeur ne correspond à critère, Choisir retourne une valeur “nulle” en rapport avec le type du paramètre valeur (par exemple 0 pour le type numérique, “” pour le type chaîne, etc.).

Cette commande permet de générer du code concis en remplacement des tests du type “Au cas ou” sur plusieurs lignes (cf. exemple 2). Elle est également très utile dans les emplacements où des formules peuvent être exécutées : éditeur de recherches, appliquer une formule, éditeur d’états rapides, colonne calculée de list box, etc.

Voici une utilisation type de la commande avec un critère booléen :

 vTitre:=Choisir([Personne]Masculin;"Mr";"Madame")

Ce code est strictement équivalent à :

 Si([Personne]Masculin)
    vTitre:="Mr"
 Sinon
    vTitre:="Madame"
 Fin de si

Voici une utilisation type de la commande avec un critère numérique :

 vStatut:=Choisir([Personne]Statut;"Célibataire";"Marié";"Veuf";"Divorcé")

Ce code est strictement équivalent à :

 Au cas ou
    :([Personne]Statut=0)
       vStatut:="Célibataire"
    :([Personne]Statut=1)
       vStatut:="Marié"
    :([Personne]Statut=2)
       vStatut:="Veuf"
    :([Personne]Statut=3)
       vStatut:="Divorcé"
 Fin de cas

 
PROPRIÉTÉS 

Produit : 4D
Thème : Outils
Numéro : 955
Nom intl. : Choose

Commande(s) éligible(s) à l'exécution dans un process préemptif

 
HISTORIQUE 

Créé : 4D v11 SQL

 
UTILISATION DE L'ARTICLE

4D - Langage ( 4D v16)
4D - Langage ( 4D v16.1)
4D - Langage ( 4D v16.2)
4D - Langage ( 4D v16.3)