Calculer une valeur (ModelBuilder)

Résumé

Renvoie une valeur en fonction d’une expression Python spécifiée.

Utilisation

  • Cet outil est prévu 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 décimales, ajoutez des décimales 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.

    Utilisation d'une variable de modèle dans l'outil Calculer une valeur
    Attention :

    Une variable en ligne de type chaîne doit être entourée de guillemets ("%variable chaîne%") dans une expression. Les variables en ligne numériques (double, long) n'ont pas besoin de guillemets (%double%).

  • 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
  • Le module random est pris en charge pour la génération de nombres aléatoires. Vous trouverez ci-dessous quelques exemples d'utilisation du module random :

    • Calculez un entier aléatoire compris entre 0 et 10 : random.randint(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 : random.normalvariate(10, 3)

    Héritage :

    arcgis.rand() n’est plus pris en charge dans la version ArcGIS Pro 2.0. Des fonctions comparables à l'aide du random module Python doivent être utilisées en lieu et place. Pour utiliser le random module avec succès, importez-le dans le paramètre Bloc de code.

  • 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.

    Utilisation d'une expression et d'un bloc de code

  • 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.

    Définition des fonctions dans le bloc de code
  • 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.

    Exemple d'utilisation de la logique If-Else

  • 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.

    Exemple d'utilisation de la méthode Python replace

  • 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.

    Exemple d'utilisation du module time de Python

  • 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.
    Utilisation de la sortie Calculer une valeur comme distance de la zone tampon

  • Vous pouvez utiliser la sortie de l’outil Calculer une valeur directement dans tous les outils Spatial Analyst qui acceptent un raster ou une valeur constante, notamment Plus, Supérieur à et Inférieur à (ces outils se trouvent dans la boîte d’outils Spatial Analyst/le 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.

    Type de données Raster (formule)

  • 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.

  • Remarque :

    Lorsque vous écrivez des scripts Python, utilisez les instructions Python standard au lieu de l'outil Calculer une valeur.

Syntaxe

arcpy.mb.CalculateValue(expression, {code_block}, {data_type})
ParamètreExplicationType de données
expression

Expression Python à résoudre.

SQL Expression
code_block
(Facultatif)

Bloc de code Python. Le code du bloc peut être référencé dans le paramètre Expression.

String
data_type
(Facultatif)

Spécifie le 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.

  • Address LocatorLocalisateur d’adresses
  • Address Locator StyleStyle de localisateur d'adresses
  • Analysis Cell SizeTaille de cellule d'analyse
  • Annotation LayerCouche d’annotations
  • Any ValueToute valeur
  • ArcMap DocumentDocument ArcMap
  • Areal UnitUnité surfacique
  • BIM File WorkspaceEspace de travail de fichier BIM
  • BooleanBooléen
  • Building Discipline LayerCréation de la couche de discipline
  • Building Discipline Scene LayerCréation de la couche de scène de discipline
  • Building LayerCréation de la couche
  • Building Scene LayerCréation de la couche de scène
  • CAD Drawing DatasetJeu de données de dessin DAO
  • Calculator ExpressionExpression de la calculatrice
  • Catalog RootRacine du catalogue
  • Cell SizeTaille de cellule
  • Cell Size XYTaille de cellule XY
  • Composite LayerCouche composite
  • CompressionCompression
  • Coordinate SystemSystème de coordonnées
  • Coordinate Systems FolderDossier des systèmes de coordonnées
  • CoverageCouverture
  • Coverage Feature ClassClasse d'entités de couverture
  • Data ElementElément de données
  • Data FileFichier de données
  • Database ConnectionsConnexions aux bases de données
  • DatasetJeu de données
  • DateDate
  • dBASE TableTable dBASE
  • DecimateEliminer
  • Diagram LayerCouche de diagramme
  • Dimension LayerCouche de dimensions
  • Disk ConnectionConnexion de disque
  • DoubleDouble
  • Elevation Surface LayerCouche de surface d’altitude
  • Encrypted StringChaîne chiffrée
  • EnvelopeEnveloppe
  • Evaluation ScaleEchelle d'évaluation
  • ExtentEtendue
  • Extract ValuesExtraire des valeurs
  • Feature ClassClasse d'entités
  • Feature DatasetJeu de classes d’entités
  • Feature LayerCouche d’entités
  • Feature SetJeu d’entités
  • FieldTerrain
  • Field InfoInformations de champ
  • Field MappingsAppariements de champs
  • FileFichier
  • FolderDossier
  • Formulated RasterRaster (formule)
  • Fuzzy functionFonction de recherche approximative
  • GeoDataServerServeur de géodonnées
  • GeodatasetJeu de données géographiques
  • Geometric NetworkRéseau géométrique
  • Geostatistical LayerCouche géostatistique
  • Geostatistical Search NeighborhoodVoisinage de recherche géostatistique
  • Geostatistical Value TableTable de valeurs géostatistiques
  • GlobeServerServeur de globe
  • GPServerServeur de géotraitement
  • GraphDiagramme
  • Graph Data TableTable de données de diagramme
  • Group LayerGroupe de couches
  • Horizontal FactorFacteur horizontal
  • Image ServiceService d’imagerie
  • Indexajusté pour les sols
  • INFO ExpressionExpression INFO
  • INFO ItemElément INFO
  • INFO TableTable INFO
  • Internet Tiled LayerCouche Internet tuilée
  • KML LayerCouche KML
  • LAS DatasetJeu de données LAS
  • LAS Dataset LayerCouche du jeu de données LAS
  • LayerCouche
  • Layer FileFichier de couches
  • LayoutMise en page
  • LineLigne
  • Linear UnitUnité linéaire
  • LongLong
  • M DomainDomaine M
  • MapCarte,
  • Map Server LayerCouche du serveur de carte
  • MapServerMapServer
  • Mosaic DatasetJeu de données mosaïque
  • Mosaic LayerCouche de mosaïque
  • NeighborhoodQuartier
  • Network Analyst Class FieldMapAppariement des champs de classe Network Analyst
  • Network Analyst Hierarchy SettingsParamètres de hiérarchie Network Analyst
  • Network Analyst LayerCouche Network Analyst
  • Network Data SourceSource de données réseau
  • Network DatasetJeu de données réseau
  • Network Dataset LayerCouche du jeu de données réseau
  • Network Travel ModeMode de déplacement réseau
  • Parcel FabricAtelier parcellaire
  • Parcel Fabric for ArcMapAtelier parcellaire pour ArcMap
  • Parcel Fabric Layer for ArcMapCouche d'atelier parcellaire pour ArcMap
  • Parcel LayerCouche de parcelle
  • PointPoint
  • PolygonSurface
  • Projection FileFichier de projection
  • PyramidPyramide
  • RadiusRayon
  • Random Number GeneratorGénérateur de nombres aléatoires
  • Raster BandBande raster
  • Raster Calculator ExpressionExpression de la calculatrice raster
  • Raster CatalogCatalogue d’images
  • Raster Catalog LayerCouche du catalogue d'images
  • Raster Data LayerCouche de données raster
  • Raster DatasetJeu de données raster
  • Raster LayerCouche raster
  • Raster StatisticsStatistiques raster
  • Raster TypeType de raster
  • Record SetJeu d'enregistrements
  • Relationship ClassClasse de relations
  • RemapClassification
  • ReportRapport
  • Route Measure Event PropertiesPropriétés des événements de mesures d'itinéraires
  • Scene LayerCouche de scène
  • SemivariogramSemi-variogramme
  • ServerConnectionServerConnection
  • ShapefileShapefile
  • Spatial ReferenceRéférence spatiale
  • SQL ExpressionExpression SQL
  • StringChaîne
  • String HiddenChaîne masquée
  • TableTableau
  • Table ViewVue tabulaire
  • Terrain LayerCouche de MNT
  • Text FileFichier texte
  • Tile SizeTaille de tuile
  • Time configurationConfiguration de temps
  • Time UnitUnités de temps
  • TINTIN
  • TIN LayerCouche du TIN
  • ToolOutil
  • ToolboxBoîte d’outils
  • Topo FeaturesEntités topologiques
  • TopologyTopologie
  • Topology LayerCouche topologique
  • Trace NetworkRéseau de traces
  • Trace Network LayerCouche de réseau de traces
  • Transformation functionFonction de transformation
  • Utility NetworkUtility Network
  • Utility Network LayerCouche de réseau de distribution
  • VariantVariante
  • Vector Tile LayerCouche de tuiles vectorielles
  • Vertical FactorFacteur vertical
  • Voxel LayerCouche de voxel
  • VPF CoverageCouverture VPF
  • VPF TableTableau VPF
  • WCS CoverageCouverture WCS
  • Weighted Overlay TableTable de superposition pondérée
  • Weighted SumSomme pondérée
  • WMS MapCarte WMS
  • WorkspaceEspace de travail
  • XY DomainDomaine XY
  • Z DomainDomaine Z
String

Sortie dérivée

NomExplicationType de données
value

Valeur calculée.

Élément de données ; couche ; vue tabulaire

Environnements

Cet outil n'utilise pas d’environnement de géotraitement.

Informations de licence

  • Basic: Oui
  • Standard: Oui
  • Advanced: Oui