Lorsqu'un outil est exécuté, ArcPy reconnaît l'application à partir de laquelle il est appelé. Ainsi, lorsque vous écrivez des messages dans Python, ceux-ci s'affichent automatiquement dans la boîte de dialogue de l'outil, dans la section historique du géotraitement et dans la fenêtre Python. Cela signifie également que tout modèle ou outil de script qui appelle votre outil a accès aux messages que vous écrivez.
Pour en savoir plus sur la messagerie, reportez-vous à la rubrique Fonctionnement des messages dans les outils de script.
Dans une boîte à outils Python, l'objet messages est utilisé pour ajouter des messages à l'outil.
Méthodes liées aux messages | Description |
---|---|
addMessage(message) | Ajoute un message informatif aux messages de l'outil |
addErrorMessage(message) | Ajoute un message d'erreur aux messages de l'outil |
addWarningMessage(message) | Ajoute un message d'avertissement aux messages de l'outil |
addIDMessage(message_type, message_ID, add_argument1=None, add_argument2=None) | Ajoute un message de tout type à l'aide de codes de message de géotraitement |
addGPMessages() | Ajoute des messages provenant de la dernière exécution de l'outil de géotraitement aux messages de l'outil |
Exemple d'ajout de messages
Dans l'exemple ci-dessous, l'entrée est évaluée, et si elle ne contient pas d'entités en entrée, un message d'erreur est ajouté à l'outil et une exception arcpy.ExecuteError est déclenchée pour fermer l'outil.
def execute(self, parameters, messages):
input = parameters[0].valueAsText
output = parameters[1].valueAsText
# If the input has no features, add an error message, and raise
# an arcpy.ExecuteError
if int(arcpy.GetCount_management(input)[0]) == 0:
messages.addErrorMessage("{0} has no features.".format(input))
raise arcpy.ExecuteError
return