2007-08-15 11:28:22 -03:00
|
|
|
|
|
|
|
.. _execmodel:
|
|
|
|
|
|
|
|
***************
|
|
|
|
Execution model
|
|
|
|
***************
|
|
|
|
|
|
|
|
.. index::
|
2015-08-05 10:07:24 -03:00
|
|
|
single: execution model
|
2007-08-15 11:28:22 -03:00
|
|
|
pair: code; block
|
|
|
|
|
2015-08-05 10:07:24 -03:00
|
|
|
.. _prog_structure:
|
2007-08-15 11:28:22 -03:00
|
|
|
|
2015-11-20 10:57:20 -04:00
|
|
|
Structure of a program
|
|
|
|
======================
|
2007-08-15 11:28:22 -03:00
|
|
|
|
2007-09-07 11:15:41 -03:00
|
|
|
.. index:: block
|
2007-08-15 11:28:22 -03:00
|
|
|
|
2015-08-05 10:07:24 -03:00
|
|
|
A Python program is constructed from code blocks.
|
2007-08-15 11:28:22 -03:00
|
|
|
A :dfn:`block` is a piece of Python program text that is executed as a unit.
|
|
|
|
The following are blocks: a module, a function body, and a class definition.
|
|
|
|
Each command typed interactively is a block. A script file (a file given as
|
2014-05-27 02:20:37 -03:00
|
|
|
standard input to the interpreter or specified as a command line argument to the
|
|
|
|
interpreter) is a code block. A script command (a command specified on the
|
2019-09-12 10:19:06 -03:00
|
|
|
interpreter command line with the :option:`-c` option) is a code block.
|
|
|
|
A module run as a top level script (as module ``__main__``) from the command
|
|
|
|
line using a :option:`-m` argument is also a code block. The string
|
2014-05-27 02:20:37 -03:00
|
|
|
argument passed to the built-in functions :func:`eval` and :func:`exec` is a
|
|
|
|
code block.
|
2007-08-15 11:28:22 -03:00
|
|
|
|
|
|
|
.. index:: pair: execution; frame
|
|
|
|
|
|
|
|
A code block is executed in an :dfn:`execution frame`. A frame contains some
|
|
|
|
administrative information (used for debugging) and determines where and how
|
|
|
|
execution continues after the code block's execution has completed.
|
|
|
|
|
2015-08-05 10:07:24 -03:00
|
|
|
.. _naming:
|
2007-08-15 11:28:22 -03:00
|
|
|
|
2015-08-05 10:07:24 -03:00
|
|
|
Naming and binding
|
|
|
|
==================
|
2007-08-15 11:28:22 -03:00
|
|
|
|
2015-08-05 10:07:24 -03:00
|
|
|
.. index::
|
|
|
|
single: namespace
|
|
|
|
single: scope
|
2007-08-15 11:28:22 -03:00
|
|
|
|
2015-08-05 10:07:24 -03:00
|
|
|
.. _bind_names:
|
2007-08-15 11:28:22 -03:00
|
|
|
|
2015-08-05 10:07:24 -03:00
|
|
|
Binding of names
|
|
|
|
----------------
|
2007-08-15 11:28:22 -03:00
|
|
|
|
|
|
|
.. index::
|
2015-08-05 10:07:24 -03:00
|
|
|
single: name
|
|
|
|
pair: binding; name
|
2007-08-15 11:28:22 -03:00
|
|
|
|
2015-08-05 10:07:24 -03:00
|
|
|
:dfn:`Names` refer to objects. Names are introduced by name binding operations.
|
2007-08-15 11:28:22 -03:00
|
|
|
|
2018-10-26 03:00:49 -03:00
|
|
|
.. index:: single: from; import statement
|
2007-08-15 11:28:22 -03:00
|
|
|
|
2021-11-26 01:19:06 -04:00
|
|
|
The following constructs bind names:
|
|
|
|
|
|
|
|
* formal parameters to functions,
|
|
|
|
* class definitions,
|
|
|
|
* function definitions,
|
|
|
|
* assignment expressions,
|
|
|
|
* :ref:`targets <assignment>` that are identifiers if occurring in
|
|
|
|
an assignment:
|
|
|
|
|
|
|
|
+ :keyword:`for` loop header,
|
|
|
|
+ after :keyword:`!as` in a :keyword:`with` statement, :keyword:`except`
|
|
|
|
clause or in the as-pattern in structural pattern matching,
|
|
|
|
+ in a capture pattern in structural pattern matching
|
|
|
|
|
|
|
|
* :keyword:`import` statements.
|
|
|
|
|
|
|
|
The :keyword:`!import` statement of the form ``from ... import *`` binds all
|
|
|
|
names defined in the imported module, except those beginning with an underscore.
|
|
|
|
This form may only be used at the module level.
|
2007-08-15 11:28:22 -03:00
|
|
|
|
|
|
|
A target occurring in a :keyword:`del` statement is also considered bound for
|
2011-02-26 17:32:16 -04:00
|
|
|
this purpose (though the actual semantics are to unbind the name).
|
2007-08-15 11:28:22 -03:00
|
|
|
|
|
|
|
Each assignment or import statement occurs within a block defined by a class or
|
|
|
|
function definition or at the module level (the top-level code block).
|
|
|
|
|
2015-08-05 10:07:24 -03:00
|
|
|
.. index:: pair: free; variable
|
|
|
|
|
|
|
|
If a name is bound in a block, it is a local variable of that block, unless
|
|
|
|
declared as :keyword:`nonlocal` or :keyword:`global`. If a name is bound at
|
|
|
|
the module level, it is a global variable. (The variables of the module code
|
|
|
|
block are local and global.) If a variable is used in a code block but not
|
|
|
|
defined there, it is a :dfn:`free variable`.
|
|
|
|
|
|
|
|
Each occurrence of a name in the program text refers to the :dfn:`binding` of
|
|
|
|
that name established by the following name resolution rules.
|
|
|
|
|
|
|
|
.. _resolve_names:
|
|
|
|
|
|
|
|
Resolution of names
|
|
|
|
-------------------
|
|
|
|
|
|
|
|
.. index:: scope
|
|
|
|
|
|
|
|
A :dfn:`scope` defines the visibility of a name within a block. If a local
|
|
|
|
variable is defined in a block, its scope includes that block. If the
|
|
|
|
definition occurs in a function block, the scope extends to any blocks contained
|
|
|
|
within the defining one, unless a contained block introduces a different binding
|
|
|
|
for the name.
|
|
|
|
|
|
|
|
.. index:: single: environment
|
|
|
|
|
|
|
|
When a name is used in a code block, it is resolved using the nearest enclosing
|
|
|
|
scope. The set of all such scopes visible to a code block is called the block's
|
|
|
|
:dfn:`environment`.
|
|
|
|
|
|
|
|
.. index::
|
|
|
|
single: NameError (built-in exception)
|
|
|
|
single: UnboundLocalError
|
|
|
|
|
|
|
|
When a name is not found at all, a :exc:`NameError` exception is raised.
|
|
|
|
If the current scope is a function scope, and the name refers to a local
|
|
|
|
variable that has not yet been bound to a value at the point where the name is
|
|
|
|
used, an :exc:`UnboundLocalError` exception is raised.
|
|
|
|
:exc:`UnboundLocalError` is a subclass of :exc:`NameError`.
|
|
|
|
|
2007-08-15 11:28:22 -03:00
|
|
|
If a name binding operation occurs anywhere within a code block, all uses of the
|
|
|
|
name within the block are treated as references to the current block. This can
|
2007-09-07 11:15:41 -03:00
|
|
|
lead to errors when a name is used within a block before it is bound. This rule
|
2007-08-15 11:28:22 -03:00
|
|
|
is subtle. Python lacks declarations and allows name binding operations to
|
|
|
|
occur anywhere within a code block. The local variables of a code block can be
|
|
|
|
determined by scanning the entire text of the block for name binding operations.
|
|
|
|
|
2021-10-16 09:55:12 -03:00
|
|
|
If the :keyword:`global` statement occurs within a block, all uses of the names
|
|
|
|
specified in the statement refer to the bindings of those names in the top-level
|
2007-09-07 11:15:41 -03:00
|
|
|
namespace. Names are resolved in the top-level namespace by searching the
|
|
|
|
global namespace, i.e. the namespace of the module containing the code block,
|
2009-07-26 11:54:51 -03:00
|
|
|
and the builtins namespace, the namespace of the module :mod:`builtins`. The
|
2021-10-16 09:55:12 -03:00
|
|
|
global namespace is searched first. If the names are not found there, the
|
2018-12-19 02:09:46 -04:00
|
|
|
builtins namespace is searched. The :keyword:`!global` statement must precede
|
2021-10-16 09:55:12 -03:00
|
|
|
all uses of the listed names.
|
2007-09-07 11:15:41 -03:00
|
|
|
|
2015-08-05 10:07:24 -03:00
|
|
|
The :keyword:`global` statement has the same scope as a name binding operation
|
|
|
|
in the same block. If the nearest enclosing scope for a free variable contains
|
|
|
|
a global statement, the free variable is treated as a global.
|
|
|
|
|
|
|
|
.. XXX say more about "nonlocal" semantics here
|
|
|
|
|
|
|
|
The :keyword:`nonlocal` statement causes corresponding names to refer
|
|
|
|
to previously bound variables in the nearest enclosing function scope.
|
|
|
|
:exc:`SyntaxError` is raised at compile time if the given name does not
|
|
|
|
exist in any enclosing function scope.
|
|
|
|
|
|
|
|
.. index:: module: __main__
|
|
|
|
|
|
|
|
The namespace for a module is automatically created the first time a module is
|
|
|
|
imported. The main module for a script is always called :mod:`__main__`.
|
|
|
|
|
|
|
|
Class definition blocks and arguments to :func:`exec` and :func:`eval` are
|
|
|
|
special in the context of name resolution.
|
|
|
|
A class definition is an executable statement that may use and define names.
|
|
|
|
These references follow the normal rules for name resolution with an exception
|
|
|
|
that unbound local variables are looked up in the global namespace.
|
|
|
|
The namespace of the class definition becomes the attribute dictionary of
|
|
|
|
the class. The scope of names defined in a class block is limited to the
|
|
|
|
class block; it does not extend to the code blocks of methods -- this includes
|
|
|
|
comprehensions and generator expressions since they are implemented using a
|
|
|
|
function scope. This means that the following will fail::
|
|
|
|
|
|
|
|
class A:
|
|
|
|
a = 42
|
|
|
|
b = list(a + i for i in range(10))
|
|
|
|
|
|
|
|
.. _restrict_exec:
|
|
|
|
|
|
|
|
Builtins and restricted execution
|
|
|
|
---------------------------------
|
2007-08-15 11:28:22 -03:00
|
|
|
|
|
|
|
.. index:: pair: restricted; execution
|
|
|
|
|
Merged revisions 75365,75394,75402-75403,75418,75459,75484,75592-75596,75600,75602-75607,75610-75613,75616-75617,75623,75627,75640,75647,75696,75795 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r75365 | georg.brandl | 2009-10-11 22:16:16 +0200 (So, 11 Okt 2009) | 1 line
Fix broken links found by "make linkcheck". scipy.org seems to be done right now, so I could not verify links going there.
........
r75394 | georg.brandl | 2009-10-13 20:10:59 +0200 (Di, 13 Okt 2009) | 1 line
Fix markup.
........
r75402 | georg.brandl | 2009-10-14 17:51:48 +0200 (Mi, 14 Okt 2009) | 1 line
#7125: fix typo.
........
r75403 | georg.brandl | 2009-10-14 17:57:46 +0200 (Mi, 14 Okt 2009) | 1 line
#7126: os.environ changes *do* take effect in subprocesses started with os.system().
........
r75418 | georg.brandl | 2009-10-14 20:48:32 +0200 (Mi, 14 Okt 2009) | 1 line
#7116: str.join() takes an iterable.
........
r75459 | georg.brandl | 2009-10-17 10:57:43 +0200 (Sa, 17 Okt 2009) | 1 line
Fix refleaks in _ctypes PyCSimpleType_New, which fixes the refleak seen in test___all__.
........
r75484 | georg.brandl | 2009-10-18 09:58:12 +0200 (So, 18 Okt 2009) | 1 line
Fix missing word.
........
r75592 | georg.brandl | 2009-10-22 09:05:48 +0200 (Do, 22 Okt 2009) | 1 line
Fix punctuation.
........
r75593 | georg.brandl | 2009-10-22 09:06:49 +0200 (Do, 22 Okt 2009) | 1 line
Revert unintended change.
........
r75594 | georg.brandl | 2009-10-22 09:56:02 +0200 (Do, 22 Okt 2009) | 1 line
Fix markup.
........
r75595 | georg.brandl | 2009-10-22 09:56:56 +0200 (Do, 22 Okt 2009) | 1 line
Fix duplicate target.
........
r75596 | georg.brandl | 2009-10-22 10:05:04 +0200 (Do, 22 Okt 2009) | 1 line
Add a new directive marking up implementation details and start using it.
........
r75600 | georg.brandl | 2009-10-22 13:01:46 +0200 (Do, 22 Okt 2009) | 1 line
Make it more robust.
........
r75602 | georg.brandl | 2009-10-22 13:28:06 +0200 (Do, 22 Okt 2009) | 1 line
Document new directive.
........
r75603 | georg.brandl | 2009-10-22 13:28:23 +0200 (Do, 22 Okt 2009) | 1 line
Allow short form with text as argument.
........
r75604 | georg.brandl | 2009-10-22 13:36:50 +0200 (Do, 22 Okt 2009) | 1 line
Fix stylesheet for multi-paragraph impl-details.
........
r75605 | georg.brandl | 2009-10-22 13:48:10 +0200 (Do, 22 Okt 2009) | 1 line
Use "impl-detail" directive where applicable.
........
r75606 | georg.brandl | 2009-10-22 17:00:06 +0200 (Do, 22 Okt 2009) | 1 line
#6324: membership test tries iteration via __iter__.
........
r75607 | georg.brandl | 2009-10-22 17:04:09 +0200 (Do, 22 Okt 2009) | 1 line
#7088: document new functions in signal as Unix-only.
........
r75610 | georg.brandl | 2009-10-22 17:27:24 +0200 (Do, 22 Okt 2009) | 1 line
Reorder __slots__ fine print and add a clarification.
........
r75611 | georg.brandl | 2009-10-22 17:42:32 +0200 (Do, 22 Okt 2009) | 1 line
#7035: improve docs of the various <method>_errors() functions, and give them docstrings.
........
r75612 | georg.brandl | 2009-10-22 17:52:15 +0200 (Do, 22 Okt 2009) | 1 line
#7156: document curses as Unix-only.
........
r75613 | georg.brandl | 2009-10-22 17:54:35 +0200 (Do, 22 Okt 2009) | 1 line
#6977: getopt does not support optional option arguments.
........
r75616 | georg.brandl | 2009-10-22 18:17:05 +0200 (Do, 22 Okt 2009) | 1 line
Add proper references.
........
r75617 | georg.brandl | 2009-10-22 18:20:55 +0200 (Do, 22 Okt 2009) | 1 line
Make printout margin important.
........
r75623 | georg.brandl | 2009-10-23 10:14:44 +0200 (Fr, 23 Okt 2009) | 1 line
#7188: fix optionxform() docs.
........
r75627 | fred.drake | 2009-10-23 15:04:51 +0200 (Fr, 23 Okt 2009) | 2 lines
add further note about what's passed to optionxform
........
r75640 | neil.schemenauer | 2009-10-23 21:58:17 +0200 (Fr, 23 Okt 2009) | 2 lines
Improve some docstrings in the 'warnings' module.
........
r75647 | georg.brandl | 2009-10-24 12:04:19 +0200 (Sa, 24 Okt 2009) | 1 line
Fix markup.
........
r75696 | georg.brandl | 2009-10-25 21:25:43 +0100 (So, 25 Okt 2009) | 1 line
Fix a demo.
........
r75795 | georg.brandl | 2009-10-27 16:10:22 +0100 (Di, 27 Okt 2009) | 1 line
Fix a strange mis-edit.
........
2009-10-27 12:28:25 -03:00
|
|
|
.. impl-detail::
|
2007-08-15 11:28:22 -03:00
|
|
|
|
|
|
|
Users should not touch ``__builtins__``; it is strictly an implementation
|
Merged revisions 78760,78771-78773,78802,78922,78952 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r78760 | georg.brandl | 2010-03-07 16:23:59 +0100 (So, 07 Mär 2010) | 1 line
#5341: more built-in vs builtin fixes.
........
r78771 | georg.brandl | 2010-03-07 21:58:31 +0100 (So, 07 Mär 2010) | 1 line
#8085: The function is called PyObject_NewVar, not PyObject_VarNew.
........
r78772 | georg.brandl | 2010-03-07 22:12:28 +0100 (So, 07 Mär 2010) | 1 line
#8039: document conditional expressions better, giving them their own section.
........
r78773 | georg.brandl | 2010-03-07 22:32:06 +0100 (So, 07 Mär 2010) | 1 line
#8044: document Py_{Enter,Leave}RecursiveCall functions.
........
r78802 | georg.brandl | 2010-03-08 17:28:40 +0100 (Mo, 08 Mär 2010) | 1 line
Fix typo.
........
r78922 | georg.brandl | 2010-03-13 14:41:58 +0100 (Sa, 13 Mär 2010) | 1 line
Update for new download location.
........
r78952 | georg.brandl | 2010-03-14 10:55:08 +0100 (So, 14 Mär 2010) | 1 line
#8137: add iso-8859-16 to the standard encodings table.
........
2010-03-14 07:56:14 -03:00
|
|
|
detail. Users wanting to override values in the builtins namespace should
|
2007-12-02 05:40:06 -04:00
|
|
|
:keyword:`import` the :mod:`builtins` module and modify its
|
2007-08-15 11:28:22 -03:00
|
|
|
attributes appropriately.
|
|
|
|
|
2017-05-22 18:09:55 -03:00
|
|
|
The builtins namespace associated with the execution of a code block
|
|
|
|
is actually found by looking up the name ``__builtins__`` in its
|
|
|
|
global namespace; this should be a dictionary or a module (in the
|
|
|
|
latter case the module's dictionary is used). By default, when in the
|
|
|
|
:mod:`__main__` module, ``__builtins__`` is the built-in module
|
|
|
|
:mod:`builtins`; when in any other module, ``__builtins__`` is an
|
|
|
|
alias for the dictionary of the :mod:`builtins` module itself.
|
|
|
|
|
|
|
|
|
2007-08-15 11:28:22 -03:00
|
|
|
.. _dynamic-features:
|
|
|
|
|
|
|
|
Interaction with dynamic features
|
|
|
|
---------------------------------
|
|
|
|
|
2015-08-05 10:07:24 -03:00
|
|
|
Name resolution of free variables occurs at runtime, not at compile time.
|
|
|
|
This means that the following code will print 42::
|
|
|
|
|
|
|
|
i = 10
|
|
|
|
def f():
|
|
|
|
print(i)
|
|
|
|
i = 42
|
|
|
|
f()
|
|
|
|
|
2007-09-07 11:15:41 -03:00
|
|
|
.. XXX from * also invalid with relative imports (at least currently)
|
|
|
|
|
|
|
|
The :func:`eval` and :func:`exec` functions do not have access to the full
|
|
|
|
environment for resolving names. Names may be resolved in the local and global
|
|
|
|
namespaces of the caller. Free variables are not resolved in the nearest
|
|
|
|
enclosing namespace, but in the global namespace. [#]_ The :func:`exec` and
|
|
|
|
:func:`eval` functions have optional arguments to override the global and local
|
|
|
|
namespace. If only one namespace is specified, it is used for both.
|
2007-08-15 11:28:22 -03:00
|
|
|
|
|
|
|
|
|
|
|
.. _exceptions:
|
|
|
|
|
|
|
|
Exceptions
|
|
|
|
==========
|
|
|
|
|
|
|
|
.. index:: single: exception
|
|
|
|
|
|
|
|
.. index::
|
|
|
|
single: raise an exception
|
|
|
|
single: handle an exception
|
|
|
|
single: exception handler
|
|
|
|
single: errors
|
|
|
|
single: error handling
|
|
|
|
|
|
|
|
Exceptions are a means of breaking out of the normal flow of control of a code
|
|
|
|
block in order to handle errors or other exceptional conditions. An exception
|
|
|
|
is *raised* at the point where the error is detected; it may be *handled* by the
|
|
|
|
surrounding code block or by any code block that directly or indirectly invoked
|
|
|
|
the code block where the error occurred.
|
|
|
|
|
|
|
|
The Python interpreter raises an exception when it detects a run-time error
|
|
|
|
(such as division by zero). A Python program can also explicitly raise an
|
|
|
|
exception with the :keyword:`raise` statement. Exception handlers are specified
|
Merged revisions 63119-63128,63130-63131,63133,63135-63144,63146-63148,63151-63152,63155-63165,63167-63176,63181-63186,63188-63189 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r63119 | benjamin.peterson | 2008-05-11 20:41:23 -0400 (Sun, 11 May 2008) | 2 lines
#2196 hasattr now allows SystemExit and KeyboardInterrupt to propagate
........
r63122 | benjamin.peterson | 2008-05-11 20:46:49 -0400 (Sun, 11 May 2008) | 2 lines
make message slightly more informative, so there's no chance of misunderstanding it
........
r63158 | ronald.oussoren | 2008-05-12 07:24:33 -0400 (Mon, 12 May 2008) | 5 lines
Remove references to platform 'mac'
The 'mac' platform (that is, os.name == 'mac') was used for the MacOS 9 port,
which is no longer supported (as of Python 2.4 IIRC).
........
r63159 | ronald.oussoren | 2008-05-12 07:31:05 -0400 (Mon, 12 May 2008) | 8 lines
MacOSX: remove dependency on Carbon package for urllib
This patch removes the dependency on the Carbon package from urllib.
The mac-specific code for getting proxy configuration is now writting in
Python using ctypes and uses the SystemConfiguration framework instead of
InternetConfig. Also provides a mac-specific implementation of proxy_bypass.
........
r63162 | eric.smith | 2008-05-12 10:00:01 -0400 (Mon, 12 May 2008) | 1 line
Added 'n' presentation type for integers.
........
r63164 | georg.brandl | 2008-05-12 12:26:52 -0400 (Mon, 12 May 2008) | 2 lines
#1713041: fix pprint's handling of maximum depth.
........
r63170 | georg.brandl | 2008-05-12 12:53:42 -0400 (Mon, 12 May 2008) | 2 lines
Fix parameter name for enumerate().
........
r63173 | georg.brandl | 2008-05-12 13:01:58 -0400 (Mon, 12 May 2008) | 2 lines
#2766: remove code without effect.
........
r63174 | georg.brandl | 2008-05-12 13:04:10 -0400 (Mon, 12 May 2008) | 3 lines
#2767: don't clear globs in run() call, since they could be needed in tearDown,
which clears them at the end.
........
r63175 | georg.brandl | 2008-05-12 13:14:51 -0400 (Mon, 12 May 2008) | 2 lines
#1760: try-except-finally is one statement since PEP 341.
........
r63186 | amaury.forgeotdarc | 2008-05-12 17:30:24 -0400 (Mon, 12 May 2008) | 2 lines
Sync code with documentation, and remove Win95 support in winsound module.
........
r63189 | amaury.forgeotdarc | 2008-05-12 18:21:39 -0400 (Mon, 12 May 2008) | 3 lines
Adapt test_pyclbr to the new version of urllib.py:
The new mac-specific functions must be ignored.
........
2008-05-15 23:54:33 -03:00
|
|
|
with the :keyword:`try` ... :keyword:`except` statement. The :keyword:`finally`
|
|
|
|
clause of such a statement can be used to specify cleanup code which does not
|
|
|
|
handle the exception, but is executed whether an exception occurred or not in
|
|
|
|
the preceding code.
|
2007-08-15 11:28:22 -03:00
|
|
|
|
|
|
|
.. index:: single: termination model
|
|
|
|
|
|
|
|
Python uses the "termination" model of error handling: an exception handler can
|
|
|
|
find out what happened and continue execution at an outer level, but it cannot
|
|
|
|
repair the cause of the error and retry the failing operation (except by
|
|
|
|
re-entering the offending piece of code from the top).
|
|
|
|
|
|
|
|
.. index:: single: SystemExit (built-in exception)
|
|
|
|
|
|
|
|
When an exception is not handled at all, the interpreter terminates execution of
|
|
|
|
the program, or returns to its interactive main loop. In either case, it prints
|
2019-05-13 10:05:20 -03:00
|
|
|
a stack traceback, except when the exception is :exc:`SystemExit`.
|
2007-08-15 11:28:22 -03:00
|
|
|
|
|
|
|
Exceptions are identified by class instances. The :keyword:`except` clause is
|
|
|
|
selected depending on the class of the instance: it must reference the class of
|
2022-03-21 17:41:35 -03:00
|
|
|
the instance or a :term:`non-virtual base class <abstract base class>` thereof.
|
|
|
|
The instance can be received by the handler and can carry additional information
|
|
|
|
about the exceptional condition.
|
2007-08-15 11:28:22 -03:00
|
|
|
|
2009-04-27 13:20:50 -03:00
|
|
|
.. note::
|
2007-08-15 11:28:22 -03:00
|
|
|
|
2007-09-07 11:15:41 -03:00
|
|
|
Exception messages are not part of the Python API. Their contents may change
|
|
|
|
from one version of Python to the next without warning and should not be
|
2007-08-15 11:28:22 -03:00
|
|
|
relied on by code which will run under multiple versions of the interpreter.
|
|
|
|
|
|
|
|
See also the description of the :keyword:`try` statement in section :ref:`try`
|
|
|
|
and :keyword:`raise` statement in section :ref:`raise`.
|
|
|
|
|
2008-07-19 12:51:07 -03:00
|
|
|
|
2007-08-15 11:28:22 -03:00
|
|
|
.. rubric:: Footnotes
|
|
|
|
|
2007-09-07 11:15:41 -03:00
|
|
|
.. [#] This limitation occurs because the code that is executed by these operations
|
|
|
|
is not available at the time the module is compiled.
|