Constantes natives¶
Un petit nombre de constantes existent dans le namespace natif. Elles sont :
-
False¶ La valeur fausse du type
bool. Les assignations àFalsene sont pas autorisées et lèvent uneSyntaxError.
-
True¶ La valeur vraie du type
bool. Les assignations àTruene sont pas autorisées et lèvent uneSyntaxError.
-
None¶ Objet utilisé fréquemment pour représenter l'absence de valeur, comme lorsque des arguments par défaut ne sont pas passés à une fonction. Les assignations à
Nonene sont pas autorisées et lèvent uneSyntaxError.Noneest la seule instance du typeNoneType.
-
NotImplemented¶ Valeur spéciale qui devrait être renvoyée par les méthodes magiques à deux opérandes (comme
__eq__(),__lt__(),__add__(),__rsub__(), etc.) pour indiquer que l'opération n'est pas implémentée pour l'autre type ; peut être renvoyée par les méthodes magiques augmentées à deux opérandes (comme__imul__(),__iand__(), etc.) avec le même objectif. Elle ne doit pas être évaluée comme booléen.NotImplementedest la seule instance detypes.NotImplementedType.Note
Lorsqu'une méthode à deux opérandes renvoie
NotImplemented, l'interpréteur essaye d'exécuter l'opération réfléchie sur l'autre type (il existe d'autres mécanismes de fallback, en fonction de l'opérateur). Si toutes les tentatives renvoientNotImplemented, l'interpréteur lève une exception appropriée. RenvoyerNotImplementedà tort donne lieu à un message d'erreur peu clair ou au renvoi de la valeurNotImplementedpour le code Python.Voir Implémentation des opérations arithmétiques pour des exemples.
Note
NotImplementedErroretNotImplementedne sont pas interchangeables, même s'ils ont un nom et un objectif similaire. VoirNotImplementedErrorpour savoir quand l'utiliser.Modifié dans la version 3.9: évaluer
NotImplementeddans un contexte booléen est obsolète. Python l'évalue aujourd'hui àTruemais émet unDeprecationWarning. Il lèvera uneTypeErrordans une version ultérieure de Python.
-
Ellipsis¶ Identique au littéral points de suspension ("
..."). Valeur spéciale utilisée principalement de manière conjointe avec la syntaxe de découpage (slicing) étendu pour les conteneurs personnalisés.Ellipsisest la seule instance detypes.EllipsisType.
-
__debug__¶ Cette constante est vraie si Python n'a pas été démarré avec une option
-O. Voir aussi l'expressionassert.
Note
Les noms None, False, True et __debug__ ne peuvent pas être réassignés (des assignations à ces noms, ou aux noms de leurs attributs, lèvent une SyntaxError), donc ils peuvent être considérés comme des "vraies" constantes.
Constantes ajoutées par le module site¶
Le module site (qui est importé automatiquement au démarrage, sauf si l'option de ligne de commande -S est donnée ajoute un certain nombre de constantes au namespace natif. Elles sont utiles pour l'interpréteur interactif et ne devraient pas être utilisées par des programmes.
-
quit(code=None)¶ -
exit(code=None)¶ Objets qui, lorsqu'ils sont représentés, affichent un message comme "Use quit() or Ctrl-D (i.e. EOF) to exit", et lorsqu'ils sont appelés, lèvent un
SystemExitavec le code de retour spécifié.
-
copyright¶ -
credits¶ Objets qui, lorsqu'ils sont affichés ou appelés, affichent le copyright ou les crédits, respectivement.
-
license¶ Objet qui, lorsqu'il est affiché, affiche un message comme "Type license() to see the full license text", et lorsqu'il est appelé, affiche le texte complet de la licence dans un style paginé (un écran à la fois).