Maison >développement back-end >Tutoriel Python >Pourquoi « counter = 1 » à l'intérieur d'une fermeture provoque-t-il une « UnboundLocalError » en Python ?
Comprendre l'erreur de variable locale non liée dans les fermetures
Lors de l'écriture de code à l'aide de fermetures, il est crucial de considérer la portée des variables. Dans ce cas particulier, la question se pose de savoir pourquoi une UnboundLocalError apparaît dans le code suivant :
counter = 0 def increment(): counter += 1 increment()
Pour répondre à cette question, il faut d'abord comprendre le concept de fermeture en Python. Une fermeture est une fonction qui conserve l'accès aux variables définies dans la portée dans laquelle elle a été définie, même après la sortie de la portée. Dans ce cas, la variable compteur est définie dans la portée globale et est référencée dans la fonction incrément(), qui est considérée comme une fermeture.
Cependant, en Python, les variables au sein d'une fonction sont automatiquement traitées comme des variables locales. sauf indication contraire explicite. Lorsque le compteur de ligne = 1 est exécuté dans incrément(), l'interpréteur tente d'incrémenter la variable du compteur local. Cependant, comme aucune valeur n’a été affectée au compteur dans la fonction incrément(), il reste indépendant. Cela entraîne la levée de l'UnboundLocalError.
Pour résoudre ce problème, il existe deux approches principales :
counter = 0 def increment(): global counter counter += 1 increment()
counter = 0 def increment(): nonlocal counter counter += 1 increment()
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!