Débogage AttributeError: l'objet 'module' n'a pas d'attribut 'Parameter' de Python Toolbox d'ArcPy?

8

J'ai un gros script .pyt (boîte à outils python) et maintenant j'essaie de le diviser en plusieurs fichiers (1 fichier - 1 outil).

Dans un seul fichier .pyt, tout fonctionne parfaitement, mais lorsque le fichier est divisé, je reçois ce message: AttributeError: l'objet 'module' n'a pas d'attribut 'Parameter'.

Structure des fichiers:

My Catalog:
-- toolbox.pyt
-- toolpackage:
---- configurator.py
---- __init__.py

toolbox.pyt:

# This Python file uses the following encoding: utf-8

import arcpy

from toolpackage.configurator import ToolboxConfigurator

class Toolbox(object):
  def __init__(self):
    """Define the toolbox (the name of the toolbox is the name of the .pyt file)."""
    self.label = "label"
    self.alias = "Tools"

    # List of tool classes associated with this toolbox
    self.tools = [ToolboxConfigurator]

configurator.py:

# This Python file uses the following encoding: utf-8

import arcpy

class ToolboxConfigurator(object):

  def __init__(self):
    """Define the tool (tool name is the name of the class)."""
    self.label              = u"config"
    self.description        = u""
    self.canRunInBackground = False

  def getParameterInfo(self):
    """Define parameter definitions"""
    new_config_file   = arcpy.Parameter(
      displayName     = u"?",
      name            = "new_config_file",
      datatype        = "GPBoolean",
      parameterType   = "Optional",
      direction       = "Input")
    parameters = [new_config_file]
    return parameters

  def isLicensed(self):
    """Set whether tool is licensed to execute."""
    return True

  def updateParameters(self, parameters):
    """Modify the values and properties of parameters before internal validation
    is performed.  This method is called whenever a parameter has been changed."""
    return

  def updateMessages(self, parameters):
    """Modify the messages created by internal validation for each tool
    parameter.  This method is called after internal validation."""
    return

  def execute(self, parameters, messages):
    """The source code of the tool."""

__init__.py est clair.

Mon erreur:

Traceback (most recent call last):
  File "C:\tools_v4\toolpackage\configurator.py", line 15, in getParameterInfo
    new_config_file   = arcpy.Parameter(
AttributeError: 'module' object has no attribute 'Parameter'
Vladimir Ivanov
la source
J'ai suivi votre structure exactement et cela fonctionne pour moi.
DWynne
2 DWynne, quelle est la version de votre logiciel?
Vladimir Ivanov
Je suis sur 10,3 (mais je pourrais vérifier assez facilement une autre version). Quelle version utilisez-vous?
DWynne
1
Rencontrer le même problème avec ArcGIS 10.3.1 Le résoudre en supprimant tous les fichiers XML créés par ArcGIS dans le dossier de la boîte à outils, redémarrer ArcGIS et réexécuter l'outil (pas dans la fenêtre de résultats mais en cliquant dessus). Semble toujours être un peu aléatoire.
Thomas
1
Je vois beaucoup cela sur 10.3.1, sur des services arcpy multi-fichiers qui fonctionnaient bien. J'ai retiré les versions précédentes de git qui fonctionnaient parfaitement, nettoyé le répertoire, effacé les services, et j'ai toujours des problèmes étrangement aléatoires.
CMPalmer

Réponses:

10

Ce n'est peut-être pas la cause pour tout le monde, mais j'ai identifié au moins un ensemble de déclencheurs.

  1. Exécuter l'outil de boîte à outils Python à partir d'ArcCatalog
  2. L'historique du géotraitement est activé et inclut un résultat du n ° 1.
  3. Lors du démarrage d'une nouvelle session ArcCatalog, aucune fenêtre de géotraitement n'est initialement ouverte (comme la fenêtre ArcToolbox, la fenêtre Python, la fenêtre Résultats).

Si ce qui précède est vrai, l'outil de boîte à outils Python affichera l' AttributeError: 'module' object has no attribute 'Parameter'exception.

Effacer l'historique (ou ne pas l'enregistrer du tout) évitera le problème, probablement pourquoi je ne l'ai pas vu auparavant car je conserve rarement mon historique.

Un clic droit sur la boîte à outils et l'utilisation de l'actualisation effacera l'erreur, mais elle réapparaîtra à l'avenir tant que la liste ci-dessus reste vraie. Cependant, si l'outil importe la classe d'outils à partir d'un fichier d'outil séparé (comme dans le cas ci-dessus), une actualisation ne sera pas suffisante. Pour cela, j'ai dû le forcer en incluant un reloaddans le .pyt, puis un rafraîchissement sur la boîte à outils effacera l'erreur.

# Using example of toolbox.pyt above
import toolpackage.configurator  # add import
reload(toolpackage.configurator)  # add a forced reload
from toolpackage.configurator import ToolboxConfigurator
DWynne
la source
Apparemment, ce bug existe toujours à 10,6 - ça me rendait fou; renommer le pyt semblait le corriger (temporairement). L'utilisation du rechargement ne l'a pas seulement corrigé, maintenant je peux utiliser le rafraîchissement pour éviter d'avoir à quitter et redémarrer constamment ArcCatalog lors du développement de code, MERCI !!
brian h wilson