Récapitulatif
L'outil Calculer une valeur renvoie une valeur basée sur une expression Python spécifiée.
Utilisation
Cet outil est prévu uniquement pour une utilisation dans ModelBuilder et non dans des scripts Python.
Le paramètre Type de données est utilisé dans ModelBuilder pour faciliter l'enchaînement de la sortie de l'outil Calculer une valeur avec d'autres outils. Par exemple, si vous utilisez l'outil Calculer une valeur pour calculer une distance à utiliser en entrée dans le paramètre Distance de la zone tampon de l'outil Zone tampon, définissez le paramètre Type de données sur Unité linéaire.
Les variables créées dans ModelBuilder peuvent être utilisées par cet outil, mais les variables qui doivent être utilisées dans le paramètre d'expression ne peuvent pas être associées à l'outil Calculer une valeur. Pour les utiliser dans l'expression, placez le nom de la variable entre des signes de pourcentage (%). Si vous souhaitez par exemple diviser une variable nommée 'Entrée' par 100, votre expression sera la suivante : %Entrée%/100.
Remarque : dans l'expression précédente, si Entrée = 123, l'expression renvoie 1. Pour obtenir des valeurs décimales, ajoutez des virgules aux valeurs dans l'expression. Par exemple : %Entrée%/100,00 renverra 1,23. L'illustration ci-dessous présente un autre exemple d'utilisation des variables dans l'expression.
Les expressions peuvent UNIQUEMENT être créées dans un format Python standard. Les autres langages de script ne sont pas pris en charge.
L'outil Calculer une valeur peut résoudre des expressions mathématiques simples. Par exemple :
- 3+5
- 9*8
- 4+(9/3)
L'outil Calculer une valeur permet d'utiliser le module mathématique Python pour effectuer des opérations mathématiques plus complexes. Pour accéder au module mathématique, faites précéder la fonction souhaitée de math. Par exemple :
- math.sqrt(25)
- math.cos(0.5)
Les constantes sont également prises en charge dans tout le module mathématique. Par exemple :
- math.pi
La fonction arcgis.rand() est prise en charge. La fonction arcgis.rand() a été créée pour les outils ArcGIS et ne doit pas être confondue avec la fonction Rand(). Vous trouverez ci-dessous quelques exemples d'utilisation de la fonction arcgis.rand() :
- Calculez une valeur aléatoire dérivée d'une distribution uniforme d'entiers compris entre 0 et 10 : arcgis.rand("Integer 0 10")
- Calculez une valeur aléatoire dérivée d'une distribution normale avec une moyenne de 10 et un écart type de 3 : arcgis.rand("Normal 10 3")
En règle générale, les expressions sont entrées dans le paramètre Expression. Les expressions plus complexes, telles que les calculs d'expressions multilignes ou les opérations logiques (if, then), impliquent l'utilisation du paramètre Bloc de code. Le paramètre Bloc de code ne peut pas être utilisé seul. Il doit être utilisé avec le paramètre Expression.
Les variables définies dans le paramètre Bloc de code peuvent être référencées à partir de l'expression.
Les fonctions peuvent être définies dans le paramètre Bloc de code et appelées à partir de l'expression. Dans l'exemple ci-dessous, la fonction renvoie une chaîne de direction du vent en fonction d'une valeur en entrée aléatoire. Dans Python, les fonctions sont définies à l'aide du mot-clé def, suivi du nom de la fonction et des paramètres en entrée de la fonction. Dans notre exemple, la fonction est getWind et le paramètre associé est wind. Les valeurs sont renvoyées à partir d'une fonction à l'aide du mot-clé return.
Vous pouvez transmettre une variable via le paramètre Expression et utiliser la logique if-else avec des variables en ligne dans le bloc de code, comme illustré ci-dessous. Le bloc de code regarde si la variable InputCellSize est vide, puis renvoie une valeur qui repose sur la condition.
Vous pouvez utiliser les méthodes Python directement dans le paramètre Expression de l'outil. Par exemple, si vous souhaitez utiliser une valeur en entrée dotée d'une virgule (valeur de champ de la table en entrée dans ce cas) dans le nom en sortie d'un autre outil via la substitution de variables en ligne, la virgule peut être remplacée avec la méthode Python replace dans l'expression de l'outil Calculer une valeur.
Les modules Python peuvent être appelés et les méthodes, telles que "replace", peuvent être combinées ou empilées dans le paramètre Bloc de code. Dans l'exemple ci-dessous, le module time est importé dans le bloc de code qui renvoie la date et l'heure actuelles, par exemple Ven Mar 19 2010 09:42:39. Cette valeur renvoyée est utilisée comme nom dans l'outil Créer un dossier afin de nommer le dossier. Comme le nom du dossier ne peut pas comporter d'espaces ou de symboles de ponctuation, la méthode replace dans Python est utilisée en empilant la méthode pour chaque élément devant être remplacé. Le nom de dossier ainsi obtenu dans cet exemple est VenMar192010094239.
Si vous calculez une valeur dans le modèle et souhaitez utiliser la valeur calculée avec des outils, tels que Zone tampon, qui nécessite une valeur de distance de la zone tampon ainsi qu'une unité linéaire, vous devez :
- renvoyer l'unité linéaire du bloc de code avec la valeur de distance ;
- modifier le type de données des valeurs renvoyées, comme indiqué ci-dessous ;
- définir le paramètre Type de données sur Unité linéaire afin que le résultat de l'expression soit converti en valeur d'unité linéaire.
Vous pouvez utiliser la sortie de l'outil Calculer une valeur directement dans tous les outils ArcGIS Spatial Analyst qui acceptent un raster ou une valeur constante, par exemple Plus, Supérieur à et Inférieur à (ces outils se trouvent dans la boîte à outils ArcGIS Spatial Analyst/jeu d'outils Mathématiques). Pour utiliser la sortie de l'outil Calculer une valeur, modifiez le type de données en sortie en Raster (formule). Ce format de type de données en sortie est une surface raster dont les valeurs de cellule sont représentées par une formule ou une constante.
Dans Python, une partie de la syntaxe est une indentation appropriée. Le niveau d'indentation (deux ou quatre espaces) importe peu tant qu'il est homogène dans tout le bloc de code.
Vous ne pouvez pas accéder aux variables de modèle dans le bloc de code. Ces variables doit être transmises au bloc de code à partir de l'expression. Pour ce faire, créez une définition dans le paramètre Bloc de code et référencez la définition dans la zone Expression.
Les variables de modèle du type liste ne doivent pas être utilisées dans la zone Expression. En raison du mode de fonctionnement des variables de liste dans ModelBuilder, l'outil Calculer une valeur s'exécute une fois avec la première valeur de la variable de liste. Les autres valeurs de la variable de liste ne sont pas transmises à l'outil Calculer une valeur.
Syntaxe
CalculateValue_management (expression, {code_block}, {data_type})
Paramètre | Explication | Type de données |
expression | Expression Python à résoudre. | SQL Expression |
code_block (Facultatif) | Code Python supplémentaire. Le code du bloc peut être référencé dans le paramètre Expression. | String |
data_type (Facultatif) | Type de données de la sortie renvoyée à partir de l'expression Python. Ce paramètre doit être utilisé dans ModelBuilder pour faciliter l'enchaînement de l'outil Calculer une valeur avec d'autres outils. | String |
Environnements
Cet outil n'utilise aucun environnement de géotraitement
Informations de licence
- ArcGIS for Desktop Basic: Oui
- ArcGIS for Desktop Standard: Oui
- ArcGIS for Desktop Advanced: Oui