Utilisation de la logique If-Then-Else pour le branchement
La logique If-Then-Else (en français, Si-Sinon-Autre) constitue est un moyen simple, mais puissant, d'effectuer des actions différentes en fonction de conditions différentes. Cette logique fonctionne comme ceci : si une condition If est remplie, une action doit être réalisée ; sinon (Else), la condition est fausse, une autre action doit être réalisée.
Utilisation de la logique If-Then-Else dans ModelBuilder
Dans ModelBuilder, vous pouvez mettre en œuvre la logique If-Then-Else en écrivant un outil de script chargé de tester une condition et de générer deux variables booléennes en sortie décrivant les conditions True et False, puis incorporer cet outil de script à un modèle. Un autre moyen consiste à utiliser l'outil Calculer une valeur pour tester la condition et générer une valeur booléenne en sortie.
Le modèle suivant inclut un outil de script appelé Check Coordinate System chargé d'utiliser la logique de branchement. Cet outil de script évalue un jeu de données en entrée et indique si ce jeu de données est associé à un système de coordonnées State Plane projetées ou à un système de coordonnées inconnu. Dans le modèle, si le jeu de données en entrée est associé à un système de coordonnées State Plane projetées, rien ne se produit. Toutefois, si le jeu de données en entrée est associé à un système de coordonnées inconnu, le modèle définit un système de projection et projette les données en entrée. L'une des étapes-clés pour l'utilisation de la logique de branchement dans ModelBuilder est de définir une des sorties conditionnelles comme pré-condition au traitement ultérieur.
Exemples de logique If-Then-Else
L'extrait de code suivant affiche comment le branchement If-Then-Else est mis en œuvre dans l'outil de script Check Coordinate System présenté ci-dessus. Le script génère deux variables en sortie, une représentant la condition If (true) et l'autre représentant la condition Else (false).
L'exemple vérifie si le système de coordonnées des données en entrée est de type StatePlane, n'a pas de système de projection (PRJ) ou est un autre système que StatePlane.
# Import modules import arcpy import sys import traceback # Set local variables prj = "" indata = "C:/ToolData/well.shp" dsc = arcpy.Describe(indata) sr = dsc.spatialReference prj = sr.name.lower() try: # check if indata is in StatePlane, has no PRJ, or one other than StatePlane if prj.find("_stateplane_") > -1: # Set the Is Unknown parameter to FALSE, and the Is StatePlane parameter to TRUE arcpy.SetParameterAsText(1,"false") #The first parameter refers to the "Is Unknown" variable arcpy.SetParameterAsText(2,"true") #The second parameter refers to the "Is StatePlane" variable arcpy.AddMessage("Coordinate system is StatePlane") elif prj == "unknown": # Set the Is Unknown parameter to TRUE, and the Is StatePlane parameter to FALSE arcpy.SetParameterAsText(1,"true") arcpy.SetParameterAsText(2,"false") arcpy.AddMessage("To continue, first define a coordinate system!") else: # Set the Is Unknown parameter to FALSE, and the Is StatePlane parameter to FALSE arcpy.SetParameterAsText(1,"false") arcpy.SetParameterAsText(2,"false") arcpy.AddMessage("Coordinate system is not StatePlane or Unknown") except: tb = sys.exc_info()[2] tbinfo = traceback.format_tb(tb)[0] pymsg = tbinfo + "\n" + str(sys.exc_type)+ ": " + str(sys.exc_value) arcpy.AddError("Python Messages: " + pymsg + " GP Messages: " + arcpy.GetMessages(2))