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

Delphi Discussion :

Conditions if/else imbriquées


Sujet :

Delphi

  1. #1
    Membre à l'essai
    Homme Profil pro
    Assistant ingénieur en ressources documentaires
    Inscrit en
    Novembre 2014
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Assistant ingénieur en ressources documentaires
    Secteur : Enseignement

    Informations forums :
    Inscription : Novembre 2014
    Messages : 22
    Points : 18
    Points
    18
    Par défaut Conditions if/else imbriquées
    Bonjour,

    Non programmeur, j'essaye d'améliorer une procédure à partir d'un vieux Fast report intégré au SIGB, qui travaille notamment avec du Delphi (je précise de suite : format de données propriétaire pas de SQL possible).
    Je rencontre actuellement un problème dans un enchaînement if/else if/.../else, il me réclame un BEGIN supplémentaire en dernière ligne que je ne comprends pas.

    je ne sais pas s'il s'agit d'un prble de syntaxe tout bête ou si je me plante complètement... J'ai aussi essayé avec un "case of" mais sans plus de succès.

    Merci d'avance pour tout conseil...

    Olivier
    here is the code...
    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
     
    procedure DonneesMaitre1OnBeforePrint(Sender: TfrxComponent);            
    var 
    Etat,Site,Emplacement,Situation:string;
    Begin          
      Site:=Trim(<Emprunteurs;Responsable légal>);
      Etat:=Trim(<Réservations;Etat>);
      Emplacement:=Trim(<Exemplaires;Emplacement>);
      Situation:=Trim(<Exemplaires;Situation>);    
     
    if (Site='Valenciennes') then
    Begin            
     DonneesMaitre1.visible:=false
     end         
     
    else if (Site='Lille') then 
    Begin
     if (Emplacement='Lille') and (Situation='Disponible') then
      DonneesMaitre1.visible:=false
     else if (Emplacement='Valenciennes') and (Situation='Disponible') then
     DonneesMaitre1.visible:=true
     else
     DonneesMaitre1.visible:=false;    
     end 
     
     else if (Site='Arras') then
     Begin
     if (Emplacement='Arras') and (Situation='Disponible') then
      DonneesMaitre1.visible:=false   
     else if (Emplacement='Valenciennes') and (Situation='Disponible') then
     DonneesMaitre1.visible:=true  
     else
     DonneesMaitre1.visible:=false;  
     end  
     
     else if (Site='Gravelines') then
     Begin
      if (Emplacement='Gravelines') and (Situation='Disponible') then
      DonneesMaitre1.visible:=false
     else if (Emplacement='Valenciennes') and (Situation='Disponible') then
     DonneesMaitre1.visible:=true  
     else
     DonneesMaitre1.visible:=false;  
     end   
     
     else
     begin             
     DonneesMaitre1.visible:=false; 
     end;
     
     end;

  2. #2
    Rédacteur/Modérateur

    Avatar de SergioMaster
    Homme Profil pro
    Développeur informatique retraité
    Inscrit en
    Janvier 2007
    Messages
    15 036
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 036
    Points : 40 941
    Points
    40 941
    Billets dans le blog
    62
    Par défaut
    Bonjour,

    il me semble que cela peut se simplifier

    déjà comme ceci
    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
     
    procedure DonneesMaitre1OnBeforePrint(Sender: TfrxComponent);            
    var 
    Etat,Site,Emplacement,Situation:string;
    Begin          
      Site:=Trim(<Emprunteurs;Responsable légal>);
      Etat:=Trim(<Réservations;Etat>);
      Emplacement:=Trim(<Exemplaires;Emplacement>);
      Situation:=Trim(<Exemplaires;Situation>); 
      //----------------------------------------Simplification 1 -----------------------
      DonneesMaitre1.visible:=false;
      if (Site='Lille') AND (Emplacement='Valenciennes') and (Situation='Disponible') then 
       begin
            DonneesMaitre1.visible:=True;
            Exit;    
       end;
      if (Site='Arras') AND (Emplacement='Valenciennes') and (Situation='Disponible') then
       begin
            DonneesMaitre1.visible:=True;
            Exit;    
       end;
      if (Site='Gravelines') AND (Emplacement='Valenciennes') and (Situation='Disponible') then
       begin
            DonneesMaitre1.visible:=True;
            Exit;    
       end; 
      // ---------------------------fin simplification --------------------------------------
    end;
    puis peut être ainsi

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
      //--------------------------- Simplification 2 -------------------------------------------------------
       DonnéesMaitre1.Visible:=  ((Site='Lille') AND (Emplacement='Valenciennes') and (Situation='Disponible'))
                                      OR ((Site='Arras') AND (Emplacement='Valenciennes') and (Situation='Disponible')) 
                                      OR ((Site='Gravelines') AND (Emplacement='Valenciennes') and (Situation='Disponible'));
      // ---------------------------fin simplification --------------------------------------
    voire même (à supposer qu'il n'y ait pas d'autres villes ayant cette condition (Emplacement='Valenciennes') and (Situation='Disponible')
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
     DonnéesMaitre1.Visible:=((Emplacement='Valenciennes') and (Situation='Disponible')) OR (Site<>'Valencienne');
    une grille de décision (tableau) aurait été bien pratique (mais je ne sais pas si ça s'enseigne encore ce genre de choses )
    MVP Embarcadero
    Delphi installés : D3,D7,D2010,XE4,XE7,D10 (Rio, Sidney), D11 (Alexandria), D12 (Athènes)
    SGBD : Firebird 2.5, 3, SQLite
    générateurs États : FastReport, Rave, QuickReport
    OS : Window Vista, Windows 10, Windows 11, Ubuntu, Androïd

  3. #3
    Rédacteur/Modérateur

    Avatar de Roland Chastain
    Homme Profil pro
    Enseignant
    Inscrit en
    Décembre 2011
    Messages
    4 072
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Décembre 2011
    Messages : 4 072
    Points : 15 462
    Points
    15 462
    Billets dans le blog
    9
    Par défaut
    Citation Envoyé par Olivier59260 Voir le message
    il me réclame un BEGIN supplémentaire en dernière ligne que je ne comprends pas.
    Bonjour !

    Bizarre, je ne vois pas de "begin" manquant dans le code. Je l'ai réindenté d'une façon qui me paraît plus claire (et légèrement modifié pour pouvoir essayer de le compiler) :

    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
    program code;
     
    uses
      SysUtils;
     
    var 
      Etat, Site, Emplacement, Situation: string;
      DonneesMaitre1: record visible: boolean; end;
     
    begin          
      Site := Trim('');
      Etat := Trim('');
      Emplacement := Trim('');
      Situation := Trim('');    
     
      if (Site = 'Valenciennes') then
      begin            
        DonneesMaitre1.visible := false
      end else
        if (Site = 'Lille') then 
        begin
          if (Emplacement = 'Lille') and (Situation = 'Disponible') then
            DonneesMaitre1.visible := false
          else
            if (Emplacement = 'Valenciennes') and (Situation = 'Disponible') then
              DonneesMaitre1.visible := true
            else
              DonneesMaitre1.visible := false;    
        end else
          if (Site = 'Arras') then
          begin
            if (Emplacement = 'Arras') and (Situation = 'Disponible') then
              DonneesMaitre1.visible := false   
            else
              if (Emplacement = 'Valenciennes') and (Situation = 'Disponible') then
                DonneesMaitre1.visible := true  
              else
                DonneesMaitre1.visible := false;  
          end else
            if (Site = 'Gravelines') then
            begin
              if (Emplacement = 'Gravelines') and (Situation = 'Disponible') then
                DonneesMaitre1.visible := false
              else
                if (Emplacement = 'Valenciennes') and (Situation = 'Disponible') then
                  DonneesMaitre1.visible := true  
                else
                  DonneesMaitre1.visible := false;  
            end else
            begin             
              DonneesMaitre1.visible := false; 
            end;
     
    end.
    Mon site personnel consacré à MSEide+MSEgui : msegui.net

  4. #4
    Membre émérite

    Homme Profil pro
    Développeur informatique
    Inscrit en
    Novembre 2007
    Messages
    3 385
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Novembre 2007
    Messages : 3 385
    Points : 2 999
    Points
    2 999
    Par défaut
    et ça, ça le ferait pas pareil ?

    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
     
    var
      Etat, Site, Emplacement, Situation: string;
      B: Boolean;
    Begin
      Site        := Trim('Emprunteurs;Responsable légal');
      Etat        := Trim('Réservations;Etat');
      Emplacement := Trim('Exemplaires;Emplacement');
      Situation   := Trim('Exemplaires;Situation');
     
      B := (Emplacement = 'Valenciennes') and (Situation = 'Disponible'));
      DonneesMaitre1.visible :=
        ( Site = 'Valenciennes' ) or
        ( (Site = 'Lille')      and B ) or
        ( (Site = 'Arras')      and B ) or
        ( (Site = 'Gravelines') and B );
     
    end;

Discussions similaires

  1. Ma condition if / else ne fonctionne pas
    Par kryogen dans le forum Général JavaScript
    Réponses: 11
    Dernier message: 11/10/2007, 18h39
  2. condition (if/else) qui ne fonctionne pas
    Par oceane751 dans le forum Langage
    Réponses: 8
    Dernier message: 24/07/2007, 23h58
  3. Condition if/else et région répétée
    Par craac dans le forum Langage
    Réponses: 6
    Dernier message: 10/04/2007, 11h20
  4. [MySQL] instruction condition if - else
    Par Henry9 dans le forum PHP & Base de données
    Réponses: 7
    Dernier message: 22/09/2006, 23h49

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