blob: ed770cb002674be1ca4f61830b999c72a573df16 [file] [log] [blame]
Georg Brandl116aa622007-08-15 14:28:22 +00001
2.. _compound:
3
4*******************
5Compound statements
6*******************
7
8.. index:: pair: compound; statement
9
10Compound statements contain (groups of) other statements; they affect or control
11the execution of those other statements in some way. In general, compound
12statements span multiple lines, although in simple incarnations a whole compound
13statement may be contained in one line.
14
15The :keyword:`if`, :keyword:`while` and :keyword:`for` statements implement
16traditional control flow constructs. :keyword:`try` specifies exception
Georg Brandl02c30562007-09-07 17:52:53 +000017handlers and/or cleanup code for a group of statements, while the
18:keyword:`with` statement allows the execution of initialization and
19finalization code around a block of code. Function and class definitions are
20also syntactically compound statements.
Georg Brandl116aa622007-08-15 14:28:22 +000021
22.. index::
23 single: clause
24 single: suite
25
26Compound statements consist of one or more 'clauses.' A clause consists of a
27header and a 'suite.' The clause headers of a particular compound statement are
28all at the same indentation level. Each clause header begins with a uniquely
29identifying keyword and ends with a colon. A suite is a group of statements
30controlled by a clause. A suite can be one or more semicolon-separated simple
31statements on the same line as the header, following the header's colon, or it
32can be one or more indented statements on subsequent lines. Only the latter
33form of suite can contain nested compound statements; the following is illegal,
34mostly because it wouldn't be clear to which :keyword:`if` clause a following
Georg Brandl02c30562007-09-07 17:52:53 +000035:keyword:`else` clause would belong::
Georg Brandl116aa622007-08-15 14:28:22 +000036
Georg Brandl6911e3c2007-09-04 07:15:32 +000037 if test1: if test2: print(x)
Georg Brandl116aa622007-08-15 14:28:22 +000038
39Also note that the semicolon binds tighter than the colon in this context, so
Georg Brandl6911e3c2007-09-04 07:15:32 +000040that in the following example, either all or none of the :func:`print` calls are
41executed::
Georg Brandl116aa622007-08-15 14:28:22 +000042
Georg Brandl6911e3c2007-09-04 07:15:32 +000043 if x < y < z: print(x); print(y); print(z)
Georg Brandl116aa622007-08-15 14:28:22 +000044
45Summarizing:
46
47.. productionlist::
48 compound_stmt: `if_stmt`
49 : | `while_stmt`
50 : | `for_stmt`
51 : | `try_stmt`
52 : | `with_stmt`
53 : | `funcdef`
54 : | `classdef`
Christian Heimesdd15f6c2008-03-16 00:07:10 +000055 : | `decorated`
Georg Brandl116aa622007-08-15 14:28:22 +000056 suite: `stmt_list` NEWLINE | NEWLINE INDENT `statement`+ DEDENT
57 statement: `stmt_list` NEWLINE | `compound_stmt`
58 stmt_list: `simple_stmt` (";" `simple_stmt`)* [";"]
59
60.. index::
61 single: NEWLINE token
62 single: DEDENT token
63 pair: dangling; else
64
65Note that statements always end in a ``NEWLINE`` possibly followed by a
Georg Brandl02c30562007-09-07 17:52:53 +000066``DEDENT``. Also note that optional continuation clauses always begin with a
Georg Brandl116aa622007-08-15 14:28:22 +000067keyword that cannot start a statement, thus there are no ambiguities (the
68'dangling :keyword:`else`' problem is solved in Python by requiring nested
69:keyword:`if` statements to be indented).
70
71The formatting of the grammar rules in the following sections places each clause
72on a separate line for clarity.
73
74
75.. _if:
Christian Heimes5b5e81c2007-12-31 16:14:33 +000076.. _elif:
77.. _else:
Georg Brandl116aa622007-08-15 14:28:22 +000078
79The :keyword:`if` statement
80===========================
81
Christian Heimesfaf2f632008-01-06 16:59:19 +000082.. index::
83 statement: if
84 keyword: elif
85 keyword: else
Georg Brandl02c30562007-09-07 17:52:53 +000086 keyword: elif
87 keyword: else
Georg Brandl116aa622007-08-15 14:28:22 +000088
89The :keyword:`if` statement is used for conditional execution:
90
91.. productionlist::
92 if_stmt: "if" `expression` ":" `suite`
93 : ( "elif" `expression` ":" `suite` )*
94 : ["else" ":" `suite`]
95
Georg Brandl116aa622007-08-15 14:28:22 +000096It selects exactly one of the suites by evaluating the expressions one by one
97until one is found to be true (see section :ref:`booleans` for the definition of
98true and false); then that suite is executed (and no other part of the
99:keyword:`if` statement is executed or evaluated). If all expressions are
100false, the suite of the :keyword:`else` clause, if present, is executed.
101
102
103.. _while:
104
105The :keyword:`while` statement
106==============================
107
108.. index::
109 statement: while
Georg Brandl02c30562007-09-07 17:52:53 +0000110 keyword: else
Georg Brandl116aa622007-08-15 14:28:22 +0000111 pair: loop; statement
Christian Heimesfaf2f632008-01-06 16:59:19 +0000112 keyword: else
Georg Brandl116aa622007-08-15 14:28:22 +0000113
114The :keyword:`while` statement is used for repeated execution as long as an
115expression is true:
116
117.. productionlist::
118 while_stmt: "while" `expression` ":" `suite`
119 : ["else" ":" `suite`]
120
Georg Brandl116aa622007-08-15 14:28:22 +0000121This repeatedly tests the expression and, if it is true, executes the first
122suite; if the expression is false (which may be the first time it is tested) the
123suite of the :keyword:`else` clause, if present, is executed and the loop
124terminates.
125
126.. index::
127 statement: break
128 statement: continue
129
130A :keyword:`break` statement executed in the first suite terminates the loop
131without executing the :keyword:`else` clause's suite. A :keyword:`continue`
132statement executed in the first suite skips the rest of the suite and goes back
133to testing the expression.
134
135
136.. _for:
137
138The :keyword:`for` statement
139============================
140
141.. index::
142 statement: for
Georg Brandl02c30562007-09-07 17:52:53 +0000143 keyword: in
144 keyword: else
145 pair: target; list
Georg Brandl116aa622007-08-15 14:28:22 +0000146 pair: loop; statement
Christian Heimesfaf2f632008-01-06 16:59:19 +0000147 keyword: in
148 keyword: else
149 pair: target; list
Georg Brandl02c30562007-09-07 17:52:53 +0000150 object: sequence
Georg Brandl116aa622007-08-15 14:28:22 +0000151
152The :keyword:`for` statement is used to iterate over the elements of a sequence
153(such as a string, tuple or list) or other iterable object:
154
155.. productionlist::
156 for_stmt: "for" `target_list` "in" `expression_list` ":" `suite`
157 : ["else" ":" `suite`]
158
Georg Brandl116aa622007-08-15 14:28:22 +0000159The expression list is evaluated once; it should yield an iterable object. An
160iterator is created for the result of the ``expression_list``. The suite is
161then executed once for each item provided by the iterator, in the order of
162ascending indices. Each item in turn is assigned to the target list using the
Georg Brandl02c30562007-09-07 17:52:53 +0000163standard rules for assignments (see :ref:`assignment`), and then the suite is
164executed. When the items are exhausted (which is immediately when the sequence
165is empty or an iterator raises a :exc:`StopIteration` exception), the suite in
Georg Brandl116aa622007-08-15 14:28:22 +0000166the :keyword:`else` clause, if present, is executed, and the loop terminates.
167
168.. index::
169 statement: break
170 statement: continue
171
172A :keyword:`break` statement executed in the first suite terminates the loop
173without executing the :keyword:`else` clause's suite. A :keyword:`continue`
174statement executed in the first suite skips the rest of the suite and continues
175with the next item, or with the :keyword:`else` clause if there was no next
176item.
177
178The suite may assign to the variable(s) in the target list; this does not affect
179the next item assigned to it.
180
181.. index::
182 builtin: range
Georg Brandl116aa622007-08-15 14:28:22 +0000183
Georg Brandl02c30562007-09-07 17:52:53 +0000184Names in the target list are not deleted when the loop is finished, but if the
185sequence is empty, it will not have been assigned to at all by the loop. Hint:
186the built-in function :func:`range` returns an iterator of integers suitable to
187emulate the effect of Pascal's ``for i := a to b do``; e.g., ``range(3)``
188returns the list ``[0, 1, 2]``.
Georg Brandl116aa622007-08-15 14:28:22 +0000189
190.. warning::
191
192 .. index::
193 single: loop; over mutable sequence
194 single: mutable sequence; loop over
195
196 There is a subtlety when the sequence is being modified by the loop (this can
Georg Brandl02c30562007-09-07 17:52:53 +0000197 only occur for mutable sequences, i.e. lists). An internal counter is used
198 to keep track of which item is used next, and this is incremented on each
Georg Brandl116aa622007-08-15 14:28:22 +0000199 iteration. When this counter has reached the length of the sequence the loop
200 terminates. This means that if the suite deletes the current (or a previous)
Georg Brandl02c30562007-09-07 17:52:53 +0000201 item from the sequence, the next item will be skipped (since it gets the
202 index of the current item which has already been treated). Likewise, if the
203 suite inserts an item in the sequence before the current item, the current
204 item will be treated again the next time through the loop. This can lead to
205 nasty bugs that can be avoided by making a temporary copy using a slice of
206 the whole sequence, e.g., ::
Georg Brandl116aa622007-08-15 14:28:22 +0000207
Georg Brandl02c30562007-09-07 17:52:53 +0000208 for x in a[:]:
209 if x < 0: a.remove(x)
Georg Brandl116aa622007-08-15 14:28:22 +0000210
211
212.. _try:
Christian Heimes5b5e81c2007-12-31 16:14:33 +0000213.. _except:
214.. _finally:
Georg Brandl116aa622007-08-15 14:28:22 +0000215
216The :keyword:`try` statement
217============================
218
Christian Heimesfaf2f632008-01-06 16:59:19 +0000219.. index::
220 statement: try
221 keyword: except
222 keyword: finally
Georg Brandl16174572007-09-01 12:38:06 +0000223.. index:: keyword: except
Georg Brandl116aa622007-08-15 14:28:22 +0000224
225The :keyword:`try` statement specifies exception handlers and/or cleanup code
226for a group of statements:
227
228.. productionlist::
229 try_stmt: try1_stmt | try2_stmt
230 try1_stmt: "try" ":" `suite`
Georg Brandl0068e2c2007-09-06 14:03:41 +0000231 : ("except" [`expression` ["as" `target`]] ":" `suite`)+
Georg Brandl116aa622007-08-15 14:28:22 +0000232 : ["else" ":" `suite`]
233 : ["finally" ":" `suite`]
234 try2_stmt: "try" ":" `suite`
235 : "finally" ":" `suite`
236
Christian Heimesfaf2f632008-01-06 16:59:19 +0000237
238The :keyword:`except` clause(s) specify one or more exception handlers. When no
Georg Brandl116aa622007-08-15 14:28:22 +0000239exception occurs in the :keyword:`try` clause, no exception handler is executed.
240When an exception occurs in the :keyword:`try` suite, a search for an exception
241handler is started. This search inspects the except clauses in turn until one
242is found that matches the exception. An expression-less except clause, if
243present, must be last; it matches any exception. For an except clause with an
244expression, that expression is evaluated, and the clause matches the exception
245if the resulting object is "compatible" with the exception. An object is
246compatible with an exception if it is the class or a base class of the exception
247object or a tuple containing an item compatible with the exception.
248
249If no except clause matches the exception, the search for an exception handler
250continues in the surrounding code and on the invocation stack. [#]_
251
252If the evaluation of an expression in the header of an except clause raises an
253exception, the original search for a handler is canceled and a search starts for
254the new exception in the surrounding code and on the call stack (it is treated
255as if the entire :keyword:`try` statement raised the exception).
256
257When a matching except clause is found, the exception is assigned to the target
Georg Brandl02c30562007-09-07 17:52:53 +0000258specified after the :keyword:`as` keyword in that except clause, if present, and
259the except clause's suite is executed. All except clauses must have an
260executable block. When the end of this block is reached, execution continues
261normally after the entire try statement. (This means that if two nested
262handlers exist for the same exception, and the exception occurs in the try
263clause of the inner handler, the outer handler will not handle the exception.)
264
265When an exception has been assigned using ``as target``, it is cleared at the
266end of the except clause. This is as if ::
267
268 except E as N:
269 foo
270
271was translated to ::
272
273 except E as N:
274 try:
275 foo
276 finally:
277 N = None
278 del N
279
280That means that you have to assign the exception to a different name if you want
281to be able to refer to it after the except clause. The reason for this is that
282with the traceback attached to them, exceptions will form a reference cycle with
283the stack frame, keeping all locals in that frame alive until the next garbage
284collection occurs.
Georg Brandl116aa622007-08-15 14:28:22 +0000285
286.. index::
287 module: sys
288 object: traceback
289
290Before an except clause's suite is executed, details about the exception are
291stored in the :mod:`sys` module and can be access via :func:`sys.exc_info`.
Georg Brandl02c30562007-09-07 17:52:53 +0000292:func:`sys.exc_info` returns a 3-tuple consisting of: ``exc_type``, the
293exception class; ``exc_value``, the exception instance; ``exc_traceback``, a
294traceback object (see section :ref:`types`) identifying the point in the program
295where the exception occurred. :func:`sys.exc_info` values are restored to their
296previous values (before the call) when returning from a function that handled an
297exception.
Georg Brandl116aa622007-08-15 14:28:22 +0000298
299.. index::
300 keyword: else
301 statement: return
302 statement: break
303 statement: continue
304
305The optional :keyword:`else` clause is executed if and when control flows off
306the end of the :keyword:`try` clause. [#]_ Exceptions in the :keyword:`else`
307clause are not handled by the preceding :keyword:`except` clauses.
308
309.. index:: keyword: finally
310
311If :keyword:`finally` is present, it specifies a 'cleanup' handler. The
312:keyword:`try` clause is executed, including any :keyword:`except` and
313:keyword:`else` clauses. If an exception occurs in any of the clauses and is
314not handled, the exception is temporarily saved. The :keyword:`finally` clause
315is executed. If there is a saved exception, it is re-raised at the end of the
316:keyword:`finally` clause. If the :keyword:`finally` clause raises another
317exception or executes a :keyword:`return` or :keyword:`break` statement, the
318saved exception is lost. The exception information is not available to the
319program during execution of the :keyword:`finally` clause.
320
321.. index::
322 statement: return
323 statement: break
324 statement: continue
325
326When a :keyword:`return`, :keyword:`break` or :keyword:`continue` statement is
327executed in the :keyword:`try` suite of a :keyword:`try`...\ :keyword:`finally`
328statement, the :keyword:`finally` clause is also executed 'on the way out.' A
329:keyword:`continue` statement is illegal in the :keyword:`finally` clause. (The
330reason is a problem with the current implementation --- this restriction may be
331lifted in the future).
332
333Additional information on exceptions can be found in section :ref:`exceptions`,
334and information on using the :keyword:`raise` statement to generate exceptions
335may be found in section :ref:`raise`.
336
337
338.. _with:
Christian Heimes5b5e81c2007-12-31 16:14:33 +0000339.. _as:
Georg Brandl116aa622007-08-15 14:28:22 +0000340
341The :keyword:`with` statement
342=============================
343
344.. index:: statement: with
345
Georg Brandl116aa622007-08-15 14:28:22 +0000346The :keyword:`with` statement is used to wrap the execution of a block with
Georg Brandl02c30562007-09-07 17:52:53 +0000347methods defined by a context manager (see section :ref:`context-managers`).
348This allows common :keyword:`try`...\ :keyword:`except`...\ :keyword:`finally`
349usage patterns to be encapsulated for convenient reuse.
Georg Brandl116aa622007-08-15 14:28:22 +0000350
351.. productionlist::
352 with_stmt: "with" `expression` ["as" `target`] ":" `suite`
353
354The execution of the :keyword:`with` statement proceeds as follows:
355
356#. The context expression is evaluated to obtain a context manager.
357
358#. The context manager's :meth:`__enter__` method is invoked.
359
360#. If a target was included in the :keyword:`with` statement, the return value
361 from :meth:`__enter__` is assigned to it.
362
363 .. note::
364
Georg Brandl02c30562007-09-07 17:52:53 +0000365 The :keyword:`with` statement guarantees that if the :meth:`__enter__`
366 method returns without an error, then :meth:`__exit__` will always be
367 called. Thus, if an error occurs during the assignment to the target
368 list, it will be treated the same as an error occurring within the suite
369 would be. See step 5 below.
Georg Brandl116aa622007-08-15 14:28:22 +0000370
371#. The suite is executed.
372
Georg Brandl02c30562007-09-07 17:52:53 +0000373#. The context manager's :meth:`__exit__` method is invoked. If an exception
Georg Brandl116aa622007-08-15 14:28:22 +0000374 caused the suite to be exited, its type, value, and traceback are passed as
375 arguments to :meth:`__exit__`. Otherwise, three :const:`None` arguments are
376 supplied.
377
378 If the suite was exited due to an exception, and the return value from the
Georg Brandl02c30562007-09-07 17:52:53 +0000379 :meth:`__exit__` method was false, the exception is reraised. If the return
Georg Brandl116aa622007-08-15 14:28:22 +0000380 value was true, the exception is suppressed, and execution continues with the
381 statement following the :keyword:`with` statement.
382
Georg Brandl02c30562007-09-07 17:52:53 +0000383 If the suite was exited for any reason other than an exception, the return
384 value from :meth:`__exit__` is ignored, and execution proceeds at the normal
385 location for the kind of exit that was taken.
Georg Brandl116aa622007-08-15 14:28:22 +0000386
Georg Brandl116aa622007-08-15 14:28:22 +0000387.. seealso::
388
389 :pep:`0343` - The "with" statement
390 The specification, background, and examples for the Python :keyword:`with`
391 statement.
392
393
394.. _function:
Christian Heimes5b5e81c2007-12-31 16:14:33 +0000395.. _def:
Georg Brandl116aa622007-08-15 14:28:22 +0000396
397Function definitions
398====================
399
400.. index::
Georg Brandl116aa622007-08-15 14:28:22 +0000401 statement: def
Christian Heimesfaf2f632008-01-06 16:59:19 +0000402 pair: function; definition
403 pair: function; name
404 pair: name; binding
Georg Brandl116aa622007-08-15 14:28:22 +0000405 object: user-defined function
406 object: function
Georg Brandl02c30562007-09-07 17:52:53 +0000407 pair: function; name
408 pair: name; binding
Georg Brandl116aa622007-08-15 14:28:22 +0000409
410A function definition defines a user-defined function object (see section
411:ref:`types`):
412
413.. productionlist::
414 funcdef: [`decorators`] "def" `funcname` "(" [`parameter_list`] ")" ["->" `expression`]? ":" `suite`
415 decorators: `decorator`+
416 decorator: "@" `dotted_name` ["(" [`argument_list` [","]] ")"] NEWLINE
Christian Heimesdd15f6c2008-03-16 00:07:10 +0000417 funcdef: "def" `funcname` "(" [`parameter_list`] ")" ":" `suite`
Georg Brandl116aa622007-08-15 14:28:22 +0000418 dotted_name: `identifier` ("." `identifier`)*
419 parameter_list: (`defparameter` ",")*
420 : ( "*" [`parameter`] ("," `defparameter`)*
421 : [, "**" `parameter`]
422 : | "**" `parameter`
423 : | `defparameter` [","] )
424 parameter: `identifier` [":" `expression`]
425 defparameter: `parameter` ["=" `expression`]
426 funcname: `identifier`
427
Georg Brandl116aa622007-08-15 14:28:22 +0000428
429A function definition is an executable statement. Its execution binds the
430function name in the current local namespace to a function object (a wrapper
431around the executable code for the function). This function object contains a
432reference to the current global namespace as the global namespace to be used
433when the function is called.
434
435The function definition does not execute the function body; this gets executed
436only when the function is called.
437
Christian Heimesdae2a892008-04-19 00:55:37 +0000438.. index::
439 statement: @
440
Christian Heimesd8654cf2007-12-02 15:22:16 +0000441A function definition may be wrapped by one or more :term:`decorator` expressions.
Georg Brandl116aa622007-08-15 14:28:22 +0000442Decorator expressions are evaluated when the function is defined, in the scope
443that contains the function definition. The result must be a callable, which is
444invoked with the function object as the only argument. The returned value is
445bound to the function name instead of the function object. Multiple decorators
Georg Brandl02c30562007-09-07 17:52:53 +0000446are applied in nested fashion. For example, the following code ::
Georg Brandl116aa622007-08-15 14:28:22 +0000447
448 @f1(arg)
449 @f2
450 def func(): pass
451
Georg Brandl02c30562007-09-07 17:52:53 +0000452is equivalent to ::
Georg Brandl116aa622007-08-15 14:28:22 +0000453
454 def func(): pass
455 func = f1(arg)(f2(func))
456
457.. index:: triple: default; parameter; value
458
459When one or more parameters have the form *parameter* ``=`` *expression*, the
460function is said to have "default parameter values." For a parameter with a
461default value, the corresponding argument may be omitted from a call, in which
462case the parameter's default value is substituted. If a parameter has a default
Georg Brandl02c30562007-09-07 17:52:53 +0000463value, all following parameters up until the "``*``" must also have a default
464value --- this is a syntactic restriction that is not expressed by the grammar.
Georg Brandl116aa622007-08-15 14:28:22 +0000465
466**Default parameter values are evaluated when the function definition is
Georg Brandl02c30562007-09-07 17:52:53 +0000467executed.** This means that the expression is evaluated once, when the function
Georg Brandl116aa622007-08-15 14:28:22 +0000468is defined, and that that same "pre-computed" value is used for each call. This
469is especially important to understand when a default parameter is a mutable
470object, such as a list or a dictionary: if the function modifies the object
471(e.g. by appending an item to a list), the default value is in effect modified.
Georg Brandl02c30562007-09-07 17:52:53 +0000472This is generally not what was intended. A way around this is to use ``None``
Georg Brandl116aa622007-08-15 14:28:22 +0000473as the default, and explicitly test for it in the body of the function, e.g.::
474
475 def whats_on_the_telly(penguin=None):
476 if penguin is None:
477 penguin = []
478 penguin.append("property of the zoo")
479 return penguin
480
Christian Heimesdae2a892008-04-19 00:55:37 +0000481.. index::
482 statement: *
483 statement: **
484
485Function call semantics are described in more detail in section :ref:`calls`. A
Georg Brandl116aa622007-08-15 14:28:22 +0000486function call always assigns values to all parameters mentioned in the parameter
487list, either from position arguments, from keyword arguments, or from default
488values. If the form "``*identifier``" is present, it is initialized to a tuple
489receiving any excess positional parameters, defaulting to the empty tuple. If
490the form "``**identifier``" is present, it is initialized to a new dictionary
491receiving any excess keyword arguments, defaulting to a new empty dictionary.
492Parameters after "``*``" or "``*identifier``" are keyword-only parameters and
493may only be passed used keyword arguments.
494
495.. index:: pair: function; annotations
496
497Parameters may have annotations of the form "``: expression``" following the
Georg Brandl02c30562007-09-07 17:52:53 +0000498parameter name. Any parameter may have an annotation even those of the form
499``*identifier`` or ``**identifier``. Functions may have "return" annotation of
500the form "``-> expression``" after the parameter list. These annotations can be
Georg Brandl116aa622007-08-15 14:28:22 +0000501any valid Python expression and are evaluated when the function definition is
Georg Brandl02c30562007-09-07 17:52:53 +0000502executed. Annotations may be evaluated in a different order than they appear in
503the source code. The presence of annotations does not change the semantics of a
504function. The annotation values are available as values of a dictionary keyed
Georg Brandl116aa622007-08-15 14:28:22 +0000505by the parameters' names in the :attr:`__annotations__` attribute of the
506function object.
507
508.. index:: pair: lambda; form
509
510It is also possible to create anonymous functions (functions not bound to a
511name), for immediate use in expressions. This uses lambda forms, described in
512section :ref:`lambda`. Note that the lambda form is merely a shorthand for a
513simplified function definition; a function defined in a ":keyword:`def`"
514statement can be passed around or assigned to another name just like a function
515defined by a lambda form. The ":keyword:`def`" form is actually more powerful
516since it allows the execution of multiple statements and annotations.
517
518**Programmer's note:** Functions are first-class objects. A "``def``" form
519executed inside a function definition defines a local function that can be
520returned or passed around. Free variables used in the nested function can
521access the local variables of the function containing the def. See section
522:ref:`naming` for details.
523
524
525.. _class:
526
527Class definitions
528=================
529
530.. index::
Georg Brandl02c30562007-09-07 17:52:53 +0000531 object: class
Christian Heimesfaf2f632008-01-06 16:59:19 +0000532 statement: class
533 pair: class; definition
Georg Brandl116aa622007-08-15 14:28:22 +0000534 pair: class; name
535 pair: name; binding
536 pair: execution; frame
Christian Heimesfaf2f632008-01-06 16:59:19 +0000537 single: inheritance
Georg Brandl116aa622007-08-15 14:28:22 +0000538
Georg Brandl02c30562007-09-07 17:52:53 +0000539A class definition defines a class object (see section :ref:`types`):
540
541.. XXX need to document PEP 3115 changes here (new metaclasses)
542
543.. productionlist::
544 classdef: [`decorators`] "class" `classname` [`inheritance`] ":" `suite`
545 inheritance: "(" [`expression_list`] ")"
546 classname: `identifier`
547
548
Georg Brandl116aa622007-08-15 14:28:22 +0000549A class definition is an executable statement. It first evaluates the
550inheritance list, if present. Each item in the inheritance list should evaluate
551to a class object or class type which allows subclassing. The class's suite is
552then executed in a new execution frame (see section :ref:`naming`), using a
553newly created local namespace and the original global namespace. (Usually, the
554suite contains only function definitions.) When the class's suite finishes
555execution, its execution frame is discarded but its local namespace is saved. A
556class object is then created using the inheritance list for the base classes and
557the saved local namespace for the attribute dictionary. The class name is bound
558to this class object in the original local namespace.
559
Georg Brandl02c30562007-09-07 17:52:53 +0000560Classes can also be decorated; as with functions, ::
561
562 @f1(arg)
563 @f2
564 class Foo: pass
565
566is equivalent to ::
567
568 class Foo: pass
569 Foo = f1(arg)(f2(Foo))
570
Georg Brandl116aa622007-08-15 14:28:22 +0000571**Programmer's note:** Variables defined in the class definition are class
Christian Heimesfaf2f632008-01-06 16:59:19 +0000572can be set in a method with ``self.name = value``. Both class and instance
573variables are accessible through the notation "``self.name``", and an instance
574variable hides a class variable with the same name when accessed in this way.
575Class variables can be used as defaults for instance variables, but using
Georg Brandl23e8db52008-04-07 19:17:06 +0000576mutable values there can lead to unexpected results. Descriptors can be used
577to create instance variables with different implementation details.
Georg Brandl85eb8c12007-08-31 16:33:38 +0000578
579.. XXX add link to descriptor docs above
Georg Brandl116aa622007-08-15 14:28:22 +0000580
Georg Brandl02c30562007-09-07 17:52:53 +0000581.. seealso::
582
583 :pep:`3129` - Class Decorators
584
Christian Heimesdd15f6c2008-03-16 00:07:10 +0000585Class definitions, like function definitions, may be wrapped by one or
586more :term:`decorator` expressions. The evaluation rules for the
587decorator expressions are the same as for functions. The result must
588be a class object, which is then bound to the class name.
Georg Brandl02c30562007-09-07 17:52:53 +0000589
590
Georg Brandl116aa622007-08-15 14:28:22 +0000591.. rubric:: Footnotes
592
Christian Heimesc3f30c42008-02-22 16:37:40 +0000593.. [#] The exception is propagated to the invocation stack only if there is no
Georg Brandl116aa622007-08-15 14:28:22 +0000594 :keyword:`finally` clause that negates the exception.
595
596.. [#] Currently, control "flows off the end" except in the case of an exception or the
597 execution of a :keyword:`return`, :keyword:`continue`, or :keyword:`break`
598 statement.