IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Python Discussion :

Message d'erreur : UnboundLocalError: local variable 'valErreur' referenced before assignment


Sujet :

Python

  1. #1
    Rédacteur

    Avatar de zoom61
    Homme Profil pro
    ...
    Inscrit en
    Janvier 2005
    Messages
    9 429
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Vienne (Limousin)

    Informations professionnelles :
    Activité : ...
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2005
    Messages : 9 429
    Points : 58 222
    Points
    58 222
    Billets dans le blog
    11
    Par défaut Message d'erreur : UnboundLocalError: local variable 'valErreur' referenced before assignment
    Bonjour,

    J'essaie d'utiliser dans une gestion des exceptions (try...except). En mettant la commande :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    valErreur = valErreur + str(row['Ref'])
    Mais quand je mets cette commande dans "except", j'obtiens le message suivant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    UnboundLocalError: local variable 'valErreur' referenced before assignment
    Voyez-vous pourquoi cela ne fonctionne pas ?

    J'ai beau essayé différentes commandes, cela ne change rien :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    global valErreur
    nonlocal valErreur
    Cdlt.
    N'oubliez pas le Tag afin de faciliter la recherche, et en votant cela permet de mieux la cibler.

    Je ne réponds pas aux messages privés s'ils sont liés à une question technique

  2. #2
    Expert éminent sénior
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 287
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 287
    Points : 36 776
    Points
    36 776
    Par défaut
    Salut,

    Si on écrit A = A + 1, çà récupère la variable A pour lui ajouter 1 et on assigne le résultat à la variable A.
    Récupérer A suppose qu'on ait assigné quelque chose à A "avant" et un message qui varie de NameError à UnboundLocalError suivant qu'on écrive cela dans une fonction ou à l'extérieur.
    Et la portée des variables n'a rien à voir avec la gestion des exceptions.

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  3. #3
    Rédacteur

    Avatar de zoom61
    Homme Profil pro
    ...
    Inscrit en
    Janvier 2005
    Messages
    9 429
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Vienne (Limousin)

    Informations professionnelles :
    Activité : ...
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2005
    Messages : 9 429
    Points : 58 222
    Points
    58 222
    Billets dans le blog
    11
    Par défaut
    Dans mon cas, j'ai mis au début :
    Ensuite dans except, j'ai mis :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    valErreur = valErreur + str(row['Ref'])
    Mais cela me met erreur, mais si je fais un :
    Cela fonctionne.

    Donc comment faire pour concaténer les données dans valErreur pour les récupérer à la fin dans un print.

    Cdlt.
    N'oubliez pas le Tag afin de faciliter la recherche, et en votant cela permet de mieux la cibler.

    Je ne réponds pas aux messages privés s'ils sont liés à une question technique

  4. #4
    Expert éminent sénior
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 287
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 287
    Points : 36 776
    Points
    36 776
    Par défaut
    Si vous ne postez pas un minimum de code qui montre le contexte dans lequel apparaît l'erreur et que vous ne mentionnez pas l'erreur... on va tourner en rond.

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  5. #5
    Rédacteur

    Avatar de zoom61
    Homme Profil pro
    ...
    Inscrit en
    Janvier 2005
    Messages
    9 429
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Vienne (Limousin)

    Informations professionnelles :
    Activité : ...
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2005
    Messages : 9 429
    Points : 58 222
    Points
    58 222
    Billets dans le blog
    11
    Par défaut
    Donc voici une partie de mon code, et c'est la ligne rouge qui ne fonctionne pas :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    dict_nom_champs = {'REF': "Ref",
                        'DT': "DTVal"}
    
    global cmptErreur
    
    def actions_appliquees_a_chaque_ligne(row):
        app.log(logging.INFO, "Référence : " + row['Ref'])
        app.browser.find_element(By.NAME, "internalRef").clear()
        app.browser.find_element(By.NAME, "internalRef").send_keys(row['Ref'])
        try:
            app.browser.find_element(By.NAME, "validate").click()
            app.wait_for_page_load(timeout=300)
            ValDonnee = app.browser.find_element(By.NAME, 'comercializationDate').get_attribute('value')
            if ValDonnee is not None:
                app.browser.find_element(By.NAME, "comercializationDate").clear()
            app.browser.find_element(By.NAME, "comercializationDate").send_keys(row['DTVal'])
            app.action_page({}, "Enregistrer les modifications")
            app.wait_for_page_load(timeout=300)
        except:
            valErreur = valErreur + str(row['Ref'])
    Mais si je mets cela fonctionne :
    N'oubliez pas le Tag afin de faciliter la recherche, et en votant cela permet de mieux la cibler.

    Je ne réponds pas aux messages privés s'ils sont liés à une question technique

  6. #6
    Rédacteur

    Avatar de zoom61
    Homme Profil pro
    ...
    Inscrit en
    Janvier 2005
    Messages
    9 429
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Vienne (Limousin)

    Informations professionnelles :
    Activité : ...
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2005
    Messages : 9 429
    Points : 58 222
    Points
    58 222
    Billets dans le blog
    11
    Par défaut
    Il suffisait juste de mettre :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    def actions_appliquees_a_chaque_ligne(row):
        global valErreur
    N'oubliez pas le Tag afin de faciliter la recherche, et en votant cela permet de mieux la cibler.

    Je ne réponds pas aux messages privés s'ils sont liés à une question technique

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 3
    Dernier message: 27/11/2020, 16h58
  2. Réponses: 3
    Dernier message: 06/03/2019, 01h58
  3. Réponses: 2
    Dernier message: 29/12/2015, 17h46
  4. Réponses: 6
    Dernier message: 10/08/2008, 16h42

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo