| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1 | .. _compound: | 
 | 2 |  | 
 | 3 | ******************* | 
 | 4 | Compound statements | 
 | 5 | ******************* | 
 | 6 |  | 
 | 7 | .. index:: pair: compound; statement | 
 | 8 |  | 
 | 9 | Compound statements contain (groups of) other statements; they affect or control | 
 | 10 | the execution of those other statements in some way.  In general, compound | 
 | 11 | statements span multiple lines, although in simple incarnations a whole compound | 
 | 12 | statement may be contained in one line. | 
 | 13 |  | 
 | 14 | The :keyword:`if`, :keyword:`while` and :keyword:`for` statements implement | 
 | 15 | traditional control flow constructs.  :keyword:`try` specifies exception | 
| Georg Brandl | 02c3056 | 2007-09-07 17:52:53 +0000 | [diff] [blame] | 16 | handlers and/or cleanup code for a group of statements, while the | 
 | 17 | :keyword:`with` statement allows the execution of initialization and | 
 | 18 | finalization code around a block of code.  Function and class definitions are | 
 | 19 | also syntactically compound statements. | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 20 |  | 
 | 21 | .. index:: | 
 | 22 |    single: clause | 
 | 23 |    single: suite | 
 | 24 |  | 
 | 25 | Compound statements consist of one or more 'clauses.'  A clause consists of a | 
 | 26 | header and a 'suite.'  The clause headers of a particular compound statement are | 
 | 27 | all at the same indentation level. Each clause header begins with a uniquely | 
 | 28 | identifying keyword and ends with a colon.  A suite is a group of statements | 
 | 29 | controlled by a clause.  A suite can be one or more semicolon-separated simple | 
 | 30 | statements on the same line as the header, following the header's colon, or it | 
 | 31 | can be one or more indented statements on subsequent lines.  Only the latter | 
 | 32 | form of suite can contain nested compound statements; the following is illegal, | 
 | 33 | mostly because it wouldn't be clear to which :keyword:`if` clause a following | 
| Georg Brandl | 02c3056 | 2007-09-07 17:52:53 +0000 | [diff] [blame] | 34 | :keyword:`else` clause would belong:: | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 35 |  | 
| Georg Brandl | 6911e3c | 2007-09-04 07:15:32 +0000 | [diff] [blame] | 36 |    if test1: if test2: print(x) | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 37 |  | 
 | 38 | Also note that the semicolon binds tighter than the colon in this context, so | 
| Georg Brandl | 6911e3c | 2007-09-04 07:15:32 +0000 | [diff] [blame] | 39 | that in the following example, either all or none of the :func:`print` calls are | 
 | 40 | executed:: | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 41 |  | 
| Georg Brandl | 6911e3c | 2007-09-04 07:15:32 +0000 | [diff] [blame] | 42 |    if x < y < z: print(x); print(y); print(z) | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 43 |  | 
 | 44 | Summarizing: | 
 | 45 |  | 
 | 46 | .. productionlist:: | 
 | 47 |    compound_stmt: `if_stmt` | 
 | 48 |                 : | `while_stmt` | 
 | 49 |                 : | `for_stmt` | 
 | 50 |                 : | `try_stmt` | 
 | 51 |                 : | `with_stmt` | 
 | 52 |                 : | `funcdef` | 
 | 53 |                 : | `classdef` | 
 | 54 |    suite: `stmt_list` NEWLINE | NEWLINE INDENT `statement`+ DEDENT | 
 | 55 |    statement: `stmt_list` NEWLINE | `compound_stmt` | 
 | 56 |    stmt_list: `simple_stmt` (";" `simple_stmt`)* [";"] | 
 | 57 |  | 
 | 58 | .. index:: | 
 | 59 |    single: NEWLINE token | 
 | 60 |    single: DEDENT token | 
 | 61 |    pair: dangling; else | 
 | 62 |  | 
 | 63 | Note that statements always end in a ``NEWLINE`` possibly followed by a | 
| Georg Brandl | 02c3056 | 2007-09-07 17:52:53 +0000 | [diff] [blame] | 64 | ``DEDENT``.  Also note that optional continuation clauses always begin with a | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 65 | keyword that cannot start a statement, thus there are no ambiguities (the | 
 | 66 | 'dangling :keyword:`else`' problem is solved in Python by requiring nested | 
 | 67 | :keyword:`if` statements to be indented). | 
 | 68 |  | 
 | 69 | The formatting of the grammar rules in the following sections places each clause | 
 | 70 | on a separate line for clarity. | 
 | 71 |  | 
 | 72 |  | 
 | 73 | .. _if: | 
| Christian Heimes | 5b5e81c | 2007-12-31 16:14:33 +0000 | [diff] [blame] | 74 | .. _elif: | 
 | 75 | .. _else: | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 76 |  | 
 | 77 | The :keyword:`if` statement | 
 | 78 | =========================== | 
 | 79 |  | 
| Christian Heimes | faf2f63 | 2008-01-06 16:59:19 +0000 | [diff] [blame] | 80 | .. index:: | 
 | 81 |    statement: if | 
 | 82 |    keyword: elif | 
 | 83 |    keyword: else | 
| Georg Brandl | 02c3056 | 2007-09-07 17:52:53 +0000 | [diff] [blame] | 84 |            keyword: elif | 
 | 85 |            keyword: else | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 86 |  | 
 | 87 | The :keyword:`if` statement is used for conditional execution: | 
 | 88 |  | 
 | 89 | .. productionlist:: | 
 | 90 |    if_stmt: "if" `expression` ":" `suite` | 
 | 91 |           : ( "elif" `expression` ":" `suite` )* | 
 | 92 |           : ["else" ":" `suite`] | 
 | 93 |  | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 94 | It selects exactly one of the suites by evaluating the expressions one by one | 
 | 95 | until one is found to be true (see section :ref:`booleans` for the definition of | 
 | 96 | true and false); then that suite is executed (and no other part of the | 
 | 97 | :keyword:`if` statement is executed or evaluated).  If all expressions are | 
 | 98 | false, the suite of the :keyword:`else` clause, if present, is executed. | 
 | 99 |  | 
 | 100 |  | 
 | 101 | .. _while: | 
 | 102 |  | 
 | 103 | The :keyword:`while` statement | 
 | 104 | ============================== | 
 | 105 |  | 
 | 106 | .. index:: | 
 | 107 |    statement: while | 
| Georg Brandl | 02c3056 | 2007-09-07 17:52:53 +0000 | [diff] [blame] | 108 |    keyword: else | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 109 |    pair: loop; statement | 
| Christian Heimes | faf2f63 | 2008-01-06 16:59:19 +0000 | [diff] [blame] | 110 |    keyword: else | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 111 |  | 
 | 112 | The :keyword:`while` statement is used for repeated execution as long as an | 
 | 113 | expression is true: | 
 | 114 |  | 
 | 115 | .. productionlist:: | 
 | 116 |    while_stmt: "while" `expression` ":" `suite` | 
 | 117 |              : ["else" ":" `suite`] | 
 | 118 |  | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 119 | This repeatedly tests the expression and, if it is true, executes the first | 
 | 120 | suite; if the expression is false (which may be the first time it is tested) the | 
 | 121 | suite of the :keyword:`else` clause, if present, is executed and the loop | 
 | 122 | terminates. | 
 | 123 |  | 
 | 124 | .. index:: | 
 | 125 |    statement: break | 
 | 126 |    statement: continue | 
 | 127 |  | 
 | 128 | A :keyword:`break` statement executed in the first suite terminates the loop | 
 | 129 | without executing the :keyword:`else` clause's suite.  A :keyword:`continue` | 
 | 130 | statement executed in the first suite skips the rest of the suite and goes back | 
 | 131 | to testing the expression. | 
 | 132 |  | 
 | 133 |  | 
 | 134 | .. _for: | 
 | 135 |  | 
 | 136 | The :keyword:`for` statement | 
 | 137 | ============================ | 
 | 138 |  | 
 | 139 | .. index:: | 
 | 140 |    statement: for | 
| Georg Brandl | 02c3056 | 2007-09-07 17:52:53 +0000 | [diff] [blame] | 141 |    keyword: in | 
 | 142 |    keyword: else | 
 | 143 |    pair: target; list | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 144 |    pair: loop; statement | 
| Christian Heimes | faf2f63 | 2008-01-06 16:59:19 +0000 | [diff] [blame] | 145 |    keyword: in | 
 | 146 |    keyword: else | 
 | 147 |    pair: target; list | 
| Georg Brandl | 02c3056 | 2007-09-07 17:52:53 +0000 | [diff] [blame] | 148 |    object: sequence | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 149 |  | 
 | 150 | The :keyword:`for` statement is used to iterate over the elements of a sequence | 
 | 151 | (such as a string, tuple or list) or other iterable object: | 
 | 152 |  | 
 | 153 | .. productionlist:: | 
 | 154 |    for_stmt: "for" `target_list` "in" `expression_list` ":" `suite` | 
 | 155 |            : ["else" ":" `suite`] | 
 | 156 |  | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 157 | The expression list is evaluated once; it should yield an iterable object.  An | 
 | 158 | iterator is created for the result of the ``expression_list``.  The suite is | 
 | 159 | then executed once for each item provided by the iterator, in the order of | 
 | 160 | ascending indices.  Each item in turn is assigned to the target list using the | 
| Georg Brandl | 02c3056 | 2007-09-07 17:52:53 +0000 | [diff] [blame] | 161 | standard rules for assignments (see :ref:`assignment`), and then the suite is | 
 | 162 | executed.  When the items are exhausted (which is immediately when the sequence | 
 | 163 | is empty or an iterator raises a :exc:`StopIteration` exception), the suite in | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 164 | the :keyword:`else` clause, if present, is executed, and the loop terminates. | 
 | 165 |  | 
 | 166 | .. index:: | 
 | 167 |    statement: break | 
 | 168 |    statement: continue | 
 | 169 |  | 
 | 170 | A :keyword:`break` statement executed in the first suite terminates the loop | 
 | 171 | without executing the :keyword:`else` clause's suite.  A :keyword:`continue` | 
 | 172 | statement executed in the first suite skips the rest of the suite and continues | 
 | 173 | with the next item, or with the :keyword:`else` clause if there was no next | 
 | 174 | item. | 
 | 175 |  | 
 | 176 | The suite may assign to the variable(s) in the target list; this does not affect | 
 | 177 | the next item assigned to it. | 
 | 178 |  | 
 | 179 | .. index:: | 
 | 180 |    builtin: range | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 181 |  | 
| Georg Brandl | 02c3056 | 2007-09-07 17:52:53 +0000 | [diff] [blame] | 182 | Names in the target list are not deleted when the loop is finished, but if the | 
 | 183 | sequence is empty, it will not have been assigned to at all by the loop.  Hint: | 
 | 184 | the built-in function :func:`range` returns an iterator of integers suitable to | 
| Benjamin Peterson | 3db5e7b | 2009-06-03 03:13:30 +0000 | [diff] [blame] | 185 | emulate the effect of Pascal's ``for i := a to b do``; e.g., ``list(range(3))`` | 
| Georg Brandl | 02c3056 | 2007-09-07 17:52:53 +0000 | [diff] [blame] | 186 | returns the list ``[0, 1, 2]``. | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 187 |  | 
| Georg Brandl | e720c0a | 2009-04-27 16:20:50 +0000 | [diff] [blame] | 188 | .. note:: | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 189 |  | 
 | 190 |    .. index:: | 
 | 191 |       single: loop; over mutable sequence | 
 | 192 |       single: mutable sequence; loop over | 
 | 193 |  | 
 | 194 |    There is a subtlety when the sequence is being modified by the loop (this can | 
| Georg Brandl | 02c3056 | 2007-09-07 17:52:53 +0000 | [diff] [blame] | 195 |    only occur for mutable sequences, i.e. lists).  An internal counter is used | 
 | 196 |    to keep track of which item is used next, and this is incremented on each | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 197 |    iteration.  When this counter has reached the length of the sequence the loop | 
 | 198 |    terminates.  This means that if the suite deletes the current (or a previous) | 
| Georg Brandl | 02c3056 | 2007-09-07 17:52:53 +0000 | [diff] [blame] | 199 |    item from the sequence, the next item will be skipped (since it gets the | 
 | 200 |    index of the current item which has already been treated).  Likewise, if the | 
 | 201 |    suite inserts an item in the sequence before the current item, the current | 
 | 202 |    item will be treated again the next time through the loop. This can lead to | 
 | 203 |    nasty bugs that can be avoided by making a temporary copy using a slice of | 
 | 204 |    the whole sequence, e.g., :: | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 205 |  | 
| Georg Brandl | 02c3056 | 2007-09-07 17:52:53 +0000 | [diff] [blame] | 206 |       for x in a[:]: | 
 | 207 |           if x < 0: a.remove(x) | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 208 |  | 
 | 209 |  | 
 | 210 | .. _try: | 
| Christian Heimes | 5b5e81c | 2007-12-31 16:14:33 +0000 | [diff] [blame] | 211 | .. _except: | 
 | 212 | .. _finally: | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 213 |  | 
 | 214 | The :keyword:`try` statement | 
 | 215 | ============================ | 
 | 216 |  | 
| Christian Heimes | faf2f63 | 2008-01-06 16:59:19 +0000 | [diff] [blame] | 217 | .. index:: | 
 | 218 |    statement: try | 
 | 219 |    keyword: except | 
 | 220 |    keyword: finally | 
| Georg Brandl | 1617457 | 2007-09-01 12:38:06 +0000 | [diff] [blame] | 221 | .. index:: keyword: except | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 222 |  | 
 | 223 | The :keyword:`try` statement specifies exception handlers and/or cleanup code | 
 | 224 | for a group of statements: | 
 | 225 |  | 
 | 226 | .. productionlist:: | 
 | 227 |    try_stmt: try1_stmt | try2_stmt | 
 | 228 |    try1_stmt: "try" ":" `suite` | 
| Georg Brandl | 0068e2c | 2007-09-06 14:03:41 +0000 | [diff] [blame] | 229 |             : ("except" [`expression` ["as" `target`]] ":" `suite`)+ | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 230 |             : ["else" ":" `suite`] | 
 | 231 |             : ["finally" ":" `suite`] | 
 | 232 |    try2_stmt: "try" ":" `suite` | 
 | 233 |             : "finally" ":" `suite` | 
 | 234 |  | 
| Christian Heimes | faf2f63 | 2008-01-06 16:59:19 +0000 | [diff] [blame] | 235 |  | 
 | 236 | The :keyword:`except` clause(s) specify one or more exception handlers. When no | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 237 | exception occurs in the :keyword:`try` clause, no exception handler is executed. | 
 | 238 | When an exception occurs in the :keyword:`try` suite, a search for an exception | 
 | 239 | handler is started.  This search inspects the except clauses in turn until one | 
 | 240 | is found that matches the exception.  An expression-less except clause, if | 
 | 241 | present, must be last; it matches any exception.  For an except clause with an | 
 | 242 | expression, that expression is evaluated, and the clause matches the exception | 
 | 243 | if the resulting object is "compatible" with the exception.  An object is | 
 | 244 | compatible with an exception if it is the class or a base class of the exception | 
 | 245 | object or a tuple containing an item compatible with the exception. | 
 | 246 |  | 
 | 247 | If no except clause matches the exception, the search for an exception handler | 
 | 248 | continues in the surrounding code and on the invocation stack.  [#]_ | 
 | 249 |  | 
 | 250 | If the evaluation of an expression in the header of an except clause raises an | 
 | 251 | exception, the original search for a handler is canceled and a search starts for | 
 | 252 | the new exception in the surrounding code and on the call stack (it is treated | 
 | 253 | as if the entire :keyword:`try` statement raised the exception). | 
 | 254 |  | 
 | 255 | When a matching except clause is found, the exception is assigned to the target | 
| Georg Brandl | 02c3056 | 2007-09-07 17:52:53 +0000 | [diff] [blame] | 256 | specified after the :keyword:`as` keyword in that except clause, if present, and | 
 | 257 | the except clause's suite is executed.  All except clauses must have an | 
 | 258 | executable block.  When the end of this block is reached, execution continues | 
 | 259 | normally after the entire try statement.  (This means that if two nested | 
 | 260 | handlers exist for the same exception, and the exception occurs in the try | 
 | 261 | clause of the inner handler, the outer handler will not handle the exception.) | 
 | 262 |  | 
 | 263 | When an exception has been assigned using ``as target``, it is cleared at the | 
 | 264 | end of the except clause.  This is as if :: | 
 | 265 |  | 
 | 266 |    except E as N: | 
 | 267 |        foo | 
 | 268 |  | 
 | 269 | was translated to :: | 
 | 270 |  | 
 | 271 |    except E as N: | 
 | 272 |        try: | 
 | 273 |            foo | 
 | 274 |        finally: | 
| Georg Brandl | 02c3056 | 2007-09-07 17:52:53 +0000 | [diff] [blame] | 275 |            del N | 
 | 276 |  | 
| Benjamin Peterson | fb288da | 2010-06-29 01:27:35 +0000 | [diff] [blame] | 277 | This means the exception must be assigned to a different name to be able to | 
 | 278 | refer to it after the except clause.  Exceptions are cleared because with the | 
 | 279 | traceback attached to them, they form a reference cycle with the stack frame, | 
 | 280 | keeping all locals in that frame alive until the next garbage collection occurs. | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 281 |  | 
 | 282 | .. index:: | 
 | 283 |    module: sys | 
 | 284 |    object: traceback | 
 | 285 |  | 
 | 286 | Before an except clause's suite is executed, details about the exception are | 
 | 287 | stored in the :mod:`sys` module and can be access via :func:`sys.exc_info`. | 
| Georg Brandl | b30f330 | 2011-01-06 09:23:56 +0000 | [diff] [blame] | 288 | :func:`sys.exc_info` returns a 3-tuple consisting of the exception class, the | 
 | 289 | exception instance and a traceback object (see section :ref:`types`) identifying | 
 | 290 | the point in the program where the exception occurred.  :func:`sys.exc_info` | 
 | 291 | values are restored to their previous values (before the call) when returning | 
 | 292 | from a function that handled an exception. | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 293 |  | 
 | 294 | .. index:: | 
 | 295 |    keyword: else | 
 | 296 |    statement: return | 
 | 297 |    statement: break | 
 | 298 |    statement: continue | 
 | 299 |  | 
 | 300 | The optional :keyword:`else` clause is executed if and when control flows off | 
 | 301 | the end of the :keyword:`try` clause. [#]_ Exceptions in the :keyword:`else` | 
 | 302 | clause are not handled by the preceding :keyword:`except` clauses. | 
 | 303 |  | 
 | 304 | .. index:: keyword: finally | 
 | 305 |  | 
 | 306 | If :keyword:`finally` is present, it specifies a 'cleanup' handler.  The | 
 | 307 | :keyword:`try` clause is executed, including any :keyword:`except` and | 
 | 308 | :keyword:`else` clauses.  If an exception occurs in any of the clauses and is | 
 | 309 | not handled, the exception is temporarily saved. The :keyword:`finally` clause | 
| Mark Dickinson | 05ee581 | 2012-09-24 20:16:38 +0100 | [diff] [blame] | 310 | is executed.  If there is a saved exception it is re-raised at the end of the | 
 | 311 | :keyword:`finally` clause.  If the :keyword:`finally` clause raises another | 
 | 312 | exception, the saved exception is set as the context of the new exception. | 
 | 313 | If the :keyword:`finally` clause executes a :keyword:`return` or :keyword:`break` | 
 | 314 | statement, the saved exception is discarded:: | 
| Andrew Svetlov | f158d86 | 2012-08-14 15:38:15 +0300 | [diff] [blame] | 315 |  | 
 | 316 |     def f(): | 
 | 317 |         try: | 
 | 318 |             1/0 | 
 | 319 |         finally: | 
 | 320 |             return 42 | 
 | 321 |  | 
 | 322 |     >>> f() | 
 | 323 |     42 | 
 | 324 |  | 
 | 325 | The exception information is not available to the program during execution of | 
 | 326 | the :keyword:`finally` clause. | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 327 |  | 
 | 328 | .. index:: | 
 | 329 |    statement: return | 
 | 330 |    statement: break | 
 | 331 |    statement: continue | 
 | 332 |  | 
 | 333 | When a :keyword:`return`, :keyword:`break` or :keyword:`continue` statement is | 
 | 334 | executed in the :keyword:`try` suite of a :keyword:`try`...\ :keyword:`finally` | 
 | 335 | statement, the :keyword:`finally` clause is also executed 'on the way out.' A | 
 | 336 | :keyword:`continue` statement is illegal in the :keyword:`finally` clause. (The | 
 | 337 | reason is a problem with the current implementation --- this restriction may be | 
 | 338 | lifted in the future). | 
 | 339 |  | 
 | 340 | Additional information on exceptions can be found in section :ref:`exceptions`, | 
 | 341 | and information on using the :keyword:`raise` statement to generate exceptions | 
 | 342 | may be found in section :ref:`raise`. | 
 | 343 |  | 
 | 344 |  | 
 | 345 | .. _with: | 
| Christian Heimes | 5b5e81c | 2007-12-31 16:14:33 +0000 | [diff] [blame] | 346 | .. _as: | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 347 |  | 
 | 348 | The :keyword:`with` statement | 
 | 349 | ============================= | 
 | 350 |  | 
 | 351 | .. index:: statement: with | 
 | 352 |  | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 353 | The :keyword:`with` statement is used to wrap the execution of a block with | 
| Georg Brandl | 02c3056 | 2007-09-07 17:52:53 +0000 | [diff] [blame] | 354 | methods defined by a context manager (see section :ref:`context-managers`). | 
 | 355 | This allows common :keyword:`try`...\ :keyword:`except`...\ :keyword:`finally` | 
 | 356 | usage patterns to be encapsulated for convenient reuse. | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 357 |  | 
 | 358 | .. productionlist:: | 
| Georg Brandl | 0c31562 | 2009-05-25 21:10:36 +0000 | [diff] [blame] | 359 |    with_stmt: "with" with_item ("," with_item)* ":" `suite` | 
 | 360 |    with_item: `expression` ["as" `target`] | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 361 |  | 
| Georg Brandl | 0c31562 | 2009-05-25 21:10:36 +0000 | [diff] [blame] | 362 | The execution of the :keyword:`with` statement with one "item" proceeds as follows: | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 363 |  | 
| Georg Brandl | 3387f48 | 2010-09-03 22:40:02 +0000 | [diff] [blame] | 364 | #. The context expression (the expression given in the :token:`with_item`) is | 
 | 365 |    evaluated to obtain a context manager. | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 366 |  | 
| Benjamin Peterson | 876b2f2 | 2009-06-28 03:18:59 +0000 | [diff] [blame] | 367 | #. The context manager's :meth:`__exit__` is loaded for later use. | 
 | 368 |  | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 369 | #. The context manager's :meth:`__enter__` method is invoked. | 
 | 370 |  | 
 | 371 | #. If a target was included in the :keyword:`with` statement, the return value | 
 | 372 |    from :meth:`__enter__` is assigned to it. | 
 | 373 |  | 
 | 374 |    .. note:: | 
 | 375 |  | 
| Georg Brandl | 02c3056 | 2007-09-07 17:52:53 +0000 | [diff] [blame] | 376 |       The :keyword:`with` statement guarantees that if the :meth:`__enter__` | 
 | 377 |       method returns without an error, then :meth:`__exit__` will always be | 
| Benjamin Peterson | 876b2f2 | 2009-06-28 03:18:59 +0000 | [diff] [blame] | 378 |       called. Thus, if an error occurs during the assignment to the target list, | 
 | 379 |       it will be treated the same as an error occurring within the suite would | 
 | 380 |       be. See step 6 below. | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 381 |  | 
 | 382 | #. The suite is executed. | 
 | 383 |  | 
| Georg Brandl | 02c3056 | 2007-09-07 17:52:53 +0000 | [diff] [blame] | 384 | #. The context manager's :meth:`__exit__` method is invoked.  If an exception | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 385 |    caused the suite to be exited, its type, value, and traceback are passed as | 
 | 386 |    arguments to :meth:`__exit__`. Otherwise, three :const:`None` arguments are | 
 | 387 |    supplied. | 
 | 388 |  | 
 | 389 |    If the suite was exited due to an exception, and the return value from the | 
| Georg Brandl | 02c3056 | 2007-09-07 17:52:53 +0000 | [diff] [blame] | 390 |    :meth:`__exit__` method was false, the exception is reraised.  If the return | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 391 |    value was true, the exception is suppressed, and execution continues with the | 
 | 392 |    statement following the :keyword:`with` statement. | 
 | 393 |  | 
| Georg Brandl | 02c3056 | 2007-09-07 17:52:53 +0000 | [diff] [blame] | 394 |    If the suite was exited for any reason other than an exception, the return | 
 | 395 |    value from :meth:`__exit__` is ignored, and execution proceeds at the normal | 
 | 396 |    location for the kind of exit that was taken. | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 397 |  | 
| Georg Brandl | 0c31562 | 2009-05-25 21:10:36 +0000 | [diff] [blame] | 398 | With more than one item, the context managers are processed as if multiple | 
 | 399 | :keyword:`with` statements were nested:: | 
 | 400 |  | 
 | 401 |    with A() as a, B() as b: | 
 | 402 |        suite | 
 | 403 |  | 
 | 404 | is equivalent to :: | 
 | 405 |  | 
 | 406 |    with A() as a: | 
 | 407 |        with B() as b: | 
 | 408 |            suite | 
 | 409 |  | 
 | 410 | .. versionchanged:: 3.1 | 
 | 411 |    Support for multiple context expressions. | 
 | 412 |  | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 413 | .. seealso:: | 
 | 414 |  | 
 | 415 |    :pep:`0343` - The "with" statement | 
 | 416 |       The specification, background, and examples for the Python :keyword:`with` | 
 | 417 |       statement. | 
 | 418 |  | 
 | 419 |  | 
| Chris Jerdonek | b430994 | 2012-12-25 14:54:44 -0800 | [diff] [blame] | 420 | .. index:: | 
 | 421 |    single: parameter; function definition | 
 | 422 |  | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 423 | .. _function: | 
| Christian Heimes | 5b5e81c | 2007-12-31 16:14:33 +0000 | [diff] [blame] | 424 | .. _def: | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 425 |  | 
 | 426 | Function definitions | 
 | 427 | ==================== | 
 | 428 |  | 
 | 429 | .. index:: | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 430 |    statement: def | 
| Christian Heimes | faf2f63 | 2008-01-06 16:59:19 +0000 | [diff] [blame] | 431 |    pair: function; definition | 
 | 432 |    pair: function; name | 
 | 433 |    pair: name; binding | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 434 |    object: user-defined function | 
 | 435 |    object: function | 
| Georg Brandl | 02c3056 | 2007-09-07 17:52:53 +0000 | [diff] [blame] | 436 |    pair: function; name | 
 | 437 |    pair: name; binding | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 438 |  | 
 | 439 | A function definition defines a user-defined function object (see section | 
 | 440 | :ref:`types`): | 
 | 441 |  | 
 | 442 | .. productionlist:: | 
| Georg Brandl | 33d1ae8 | 2008-09-21 07:40:25 +0000 | [diff] [blame] | 443 |    funcdef: [`decorators`] "def" `funcname` "(" [`parameter_list`] ")" ["->" `expression`] ":" `suite` | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 444 |    decorators: `decorator`+ | 
| Benjamin Peterson | 57f97f4 | 2011-12-23 20:01:43 -0600 | [diff] [blame] | 445 |    decorator: "@" `dotted_name` ["(" [`parameter_list` [","]] ")"] NEWLINE | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 446 |    dotted_name: `identifier` ("." `identifier`)* | 
 | 447 |    parameter_list: (`defparameter` ",")* | 
| Chris Jerdonek | c131b07 | 2012-10-25 17:21:22 -0700 | [diff] [blame] | 448 |                  : ( "*" [`parameter`] ("," `defparameter`)* ["," "**" `parameter`] | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 449 |                  : | "**" `parameter` | 
 | 450 |                  : | `defparameter` [","] ) | 
 | 451 |    parameter: `identifier` [":" `expression`] | 
 | 452 |    defparameter: `parameter` ["=" `expression`] | 
 | 453 |    funcname: `identifier` | 
 | 454 |  | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 455 |  | 
 | 456 | A function definition is an executable statement.  Its execution binds the | 
 | 457 | function name in the current local namespace to a function object (a wrapper | 
 | 458 | around the executable code for the function).  This function object contains a | 
 | 459 | reference to the current global namespace as the global namespace to be used | 
 | 460 | when the function is called. | 
 | 461 |  | 
 | 462 | The function definition does not execute the function body; this gets executed | 
| Georg Brandl | 3dbca81 | 2008-07-23 16:10:53 +0000 | [diff] [blame] | 463 | only when the function is called. [#]_ | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 464 |  | 
| Christian Heimes | dae2a89 | 2008-04-19 00:55:37 +0000 | [diff] [blame] | 465 | .. index:: | 
 | 466 |   statement: @ | 
 | 467 |  | 
| Christian Heimes | d8654cf | 2007-12-02 15:22:16 +0000 | [diff] [blame] | 468 | A function definition may be wrapped by one or more :term:`decorator` expressions. | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 469 | Decorator expressions are evaluated when the function is defined, in the scope | 
 | 470 | that contains the function definition.  The result must be a callable, which is | 
 | 471 | invoked with the function object as the only argument. The returned value is | 
 | 472 | bound to the function name instead of the function object.  Multiple decorators | 
| Georg Brandl | 02c3056 | 2007-09-07 17:52:53 +0000 | [diff] [blame] | 473 | are applied in nested fashion. For example, the following code :: | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 474 |  | 
 | 475 |    @f1(arg) | 
 | 476 |    @f2 | 
 | 477 |    def func(): pass | 
 | 478 |  | 
| Georg Brandl | 02c3056 | 2007-09-07 17:52:53 +0000 | [diff] [blame] | 479 | is equivalent to :: | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 480 |  | 
 | 481 |    def func(): pass | 
 | 482 |    func = f1(arg)(f2(func)) | 
 | 483 |  | 
| Chris Jerdonek | b430994 | 2012-12-25 14:54:44 -0800 | [diff] [blame] | 484 | .. index:: | 
 | 485 |    triple: default; parameter; value | 
 | 486 |    single: argument; function definition | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 487 |  | 
| Chris Jerdonek | b430994 | 2012-12-25 14:54:44 -0800 | [diff] [blame] | 488 | When one or more :term:`parameters <parameter>` have the form *parameter* ``=`` | 
 | 489 | *expression*, the function is said to have "default parameter values."  For a | 
 | 490 | parameter with a default value, the corresponding :term:`argument` may be | 
 | 491 | omitted from a call, in which | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 492 | case the parameter's default value is substituted.  If a parameter has a default | 
| Georg Brandl | 02c3056 | 2007-09-07 17:52:53 +0000 | [diff] [blame] | 493 | value, all following parameters up until the "``*``" must also have a default | 
 | 494 | value --- this is a syntactic restriction that is not expressed by the grammar. | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 495 |  | 
| Benjamin Peterson | 1ef876c | 2013-02-10 09:29:59 -0500 | [diff] [blame] | 496 | **Default parameter values are evaluated from left to right when the function | 
 | 497 | definition is executed.** This means that the expression is evaluated once, when | 
 | 498 | the function is defined, and that the same "pre-computed" value is used for each | 
 | 499 | call.  This is especially important to understand when a default parameter is a | 
 | 500 | mutable object, such as a list or a dictionary: if the function modifies the | 
 | 501 | object (e.g. by appending an item to a list), the default value is in effect | 
 | 502 | modified.  This is generally not what was intended.  A way around this is to use | 
 | 503 | ``None`` as the default, and explicitly test for it in the body of the function, | 
 | 504 | e.g.:: | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 505 |  | 
 | 506 |    def whats_on_the_telly(penguin=None): | 
 | 507 |        if penguin is None: | 
 | 508 |            penguin = [] | 
 | 509 |        penguin.append("property of the zoo") | 
 | 510 |        return penguin | 
 | 511 |  | 
| Christian Heimes | dae2a89 | 2008-04-19 00:55:37 +0000 | [diff] [blame] | 512 | .. index:: | 
 | 513 |   statement: * | 
 | 514 |   statement: ** | 
 | 515 |  | 
 | 516 | Function call semantics are described in more detail in section :ref:`calls`. A | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 517 | function call always assigns values to all parameters mentioned in the parameter | 
 | 518 | list, either from position arguments, from keyword arguments, or from default | 
 | 519 | values.  If the form "``*identifier``" is present, it is initialized to a tuple | 
 | 520 | receiving any excess positional parameters, defaulting to the empty tuple.  If | 
 | 521 | the form "``**identifier``" is present, it is initialized to a new dictionary | 
 | 522 | receiving any excess keyword arguments, defaulting to a new empty dictionary. | 
 | 523 | Parameters after "``*``" or "``*identifier``" are keyword-only parameters and | 
 | 524 | may only be passed used keyword arguments. | 
 | 525 |  | 
 | 526 | .. index:: pair: function; annotations | 
 | 527 |  | 
 | 528 | Parameters may have annotations of the form "``: expression``" following the | 
| Georg Brandl | 02c3056 | 2007-09-07 17:52:53 +0000 | [diff] [blame] | 529 | parameter name.  Any parameter may have an annotation even those of the form | 
 | 530 | ``*identifier`` or ``**identifier``.  Functions may have "return" annotation of | 
 | 531 | the form "``-> expression``" after the parameter list.  These annotations can be | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 532 | any valid Python expression and are evaluated when the function definition is | 
| Georg Brandl | 02c3056 | 2007-09-07 17:52:53 +0000 | [diff] [blame] | 533 | executed.  Annotations may be evaluated in a different order than they appear in | 
 | 534 | the source code.  The presence of annotations does not change the semantics of a | 
 | 535 | function.  The annotation values are available as values of a dictionary keyed | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 536 | by the parameters' names in the :attr:`__annotations__` attribute of the | 
 | 537 | function object. | 
 | 538 |  | 
| Georg Brandl | 242e6a0 | 2013-10-06 10:28:39 +0200 | [diff] [blame] | 539 | .. index:: pair: lambda; expression | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 540 |  | 
 | 541 | It is also possible to create anonymous functions (functions not bound to a | 
| Georg Brandl | 242e6a0 | 2013-10-06 10:28:39 +0200 | [diff] [blame] | 542 | name), for immediate use in expressions.  This uses lambda expressions, described in | 
 | 543 | section :ref:`lambda`.  Note that the lambda expression is merely a shorthand for a | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 544 | simplified function definition; a function defined in a ":keyword:`def`" | 
 | 545 | statement can be passed around or assigned to another name just like a function | 
| Georg Brandl | 242e6a0 | 2013-10-06 10:28:39 +0200 | [diff] [blame] | 546 | defined by a lambda expression.  The ":keyword:`def`" form is actually more powerful | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 547 | since it allows the execution of multiple statements and annotations. | 
 | 548 |  | 
| Georg Brandl | 242e6a0 | 2013-10-06 10:28:39 +0200 | [diff] [blame] | 549 | **Programmer's note:** Functions are first-class objects.  A "``def``" statement | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 550 | executed inside a function definition defines a local function that can be | 
 | 551 | returned or passed around.  Free variables used in the nested function can | 
 | 552 | access the local variables of the function containing the def.  See section | 
 | 553 | :ref:`naming` for details. | 
 | 554 |  | 
| Georg Brandl | 64a4094 | 2012-03-10 09:22:47 +0100 | [diff] [blame] | 555 | .. seealso:: | 
 | 556 |  | 
 | 557 |    :pep:`3107` - Function Annotations | 
 | 558 |       The original specification for function annotations. | 
 | 559 |  | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 560 |  | 
 | 561 | .. _class: | 
 | 562 |  | 
 | 563 | Class definitions | 
 | 564 | ================= | 
 | 565 |  | 
 | 566 | .. index:: | 
| Georg Brandl | 02c3056 | 2007-09-07 17:52:53 +0000 | [diff] [blame] | 567 |    object: class | 
| Christian Heimes | faf2f63 | 2008-01-06 16:59:19 +0000 | [diff] [blame] | 568 |    statement: class | 
 | 569 |    pair: class; definition | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 570 |    pair: class; name | 
 | 571 |    pair: name; binding | 
 | 572 |    pair: execution; frame | 
| Christian Heimes | faf2f63 | 2008-01-06 16:59:19 +0000 | [diff] [blame] | 573 |    single: inheritance | 
| Georg Brandl | 3dbca81 | 2008-07-23 16:10:53 +0000 | [diff] [blame] | 574 |    single: docstring | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 575 |  | 
| Georg Brandl | 02c3056 | 2007-09-07 17:52:53 +0000 | [diff] [blame] | 576 | A class definition defines a class object (see section :ref:`types`): | 
 | 577 |  | 
| Georg Brandl | 02c3056 | 2007-09-07 17:52:53 +0000 | [diff] [blame] | 578 | .. productionlist:: | 
 | 579 |    classdef: [`decorators`] "class" `classname` [`inheritance`] ":" `suite` | 
| Benjamin Peterson | ad17358 | 2011-12-23 20:00:56 -0600 | [diff] [blame] | 580 |    inheritance: "(" [`parameter_list`] ")" | 
| Georg Brandl | 02c3056 | 2007-09-07 17:52:53 +0000 | [diff] [blame] | 581 |    classname: `identifier` | 
 | 582 |  | 
| Georg Brandl | 65e5f80 | 2010-08-02 18:10:13 +0000 | [diff] [blame] | 583 | A class definition is an executable statement.  The inheritance list usually | 
 | 584 | gives a list of base classes (see :ref:`metaclasses` for more advanced uses), so | 
 | 585 | each item in the list should evaluate to a class object which allows | 
| Éric Araujo | 28053fb | 2010-11-22 03:09:19 +0000 | [diff] [blame] | 586 | subclassing.  Classes without an inheritance list inherit, by default, from the | 
 | 587 | base class :class:`object`; hence, :: | 
 | 588 |  | 
 | 589 |    class Foo: | 
 | 590 |        pass | 
 | 591 |  | 
 | 592 | is equivalent to :: | 
 | 593 |  | 
 | 594 |    class Foo(object): | 
 | 595 |        pass | 
| Georg Brandl | 65e5f80 | 2010-08-02 18:10:13 +0000 | [diff] [blame] | 596 |  | 
 | 597 | The class's suite is then executed in a new execution frame (see :ref:`naming`), | 
 | 598 | using a newly created local namespace and the original global namespace. | 
 | 599 | (Usually, the suite contains mostly function definitions.)  When the class's | 
 | 600 | suite finishes execution, its execution frame is discarded but its local | 
 | 601 | namespace is saved. [#]_ A class object is then created using the inheritance | 
 | 602 | list for the base classes and the saved local namespace for the attribute | 
 | 603 | dictionary.  The class name is bound to this class object in the original local | 
 | 604 | namespace. | 
 | 605 |  | 
 | 606 | Class creation can be customized heavily using :ref:`metaclasses <metaclasses>`. | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 607 |  | 
| Georg Brandl | f414272 | 2010-10-17 10:38:20 +0000 | [diff] [blame] | 608 | Classes can also be decorated: just like when decorating functions, :: | 
| Georg Brandl | 02c3056 | 2007-09-07 17:52:53 +0000 | [diff] [blame] | 609 |  | 
 | 610 |    @f1(arg) | 
 | 611 |    @f2 | 
 | 612 |    class Foo: pass | 
 | 613 |  | 
 | 614 | is equivalent to :: | 
 | 615 |  | 
 | 616 |    class Foo: pass | 
 | 617 |    Foo = f1(arg)(f2(Foo)) | 
 | 618 |  | 
| Georg Brandl | f414272 | 2010-10-17 10:38:20 +0000 | [diff] [blame] | 619 | The evaluation rules for the decorator expressions are the same as for function | 
 | 620 | decorators.  The result must be a class object, which is then bound to the class | 
 | 621 | name. | 
 | 622 |  | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 623 | **Programmer's note:** Variables defined in the class definition are class | 
| Georg Brandl | 65e5f80 | 2010-08-02 18:10:13 +0000 | [diff] [blame] | 624 | attributes; they are shared by instances.  Instance attributes can be set in a | 
 | 625 | method with ``self.name = value``.  Both class and instance attributes are | 
 | 626 | accessible through the notation "``self.name``", and an instance attribute hides | 
 | 627 | a class attribute with the same name when accessed in this way.  Class | 
 | 628 | attributes can be used as defaults for instance attributes, but using mutable | 
 | 629 | values there can lead to unexpected results.  :ref:`Descriptors <descriptors>` | 
 | 630 | can be used to create instance variables with different implementation details. | 
| Georg Brandl | 85eb8c1 | 2007-08-31 16:33:38 +0000 | [diff] [blame] | 631 |  | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 632 |  | 
| Georg Brandl | 02c3056 | 2007-09-07 17:52:53 +0000 | [diff] [blame] | 633 | .. seealso:: | 
 | 634 |  | 
| Ezio Melotti | 7885833 | 2011-03-11 20:50:42 +0200 | [diff] [blame] | 635 |    :pep:`3115` - Metaclasses in Python 3 | 
| Georg Brandl | 02c3056 | 2007-09-07 17:52:53 +0000 | [diff] [blame] | 636 |    :pep:`3129` - Class Decorators | 
 | 637 |  | 
| Georg Brandl | 02c3056 | 2007-09-07 17:52:53 +0000 | [diff] [blame] | 638 |  | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 639 | .. rubric:: Footnotes | 
 | 640 |  | 
| Ezio Melotti | fc3db8a | 2011-06-26 11:25:28 +0300 | [diff] [blame] | 641 | .. [#] The exception is propagated to the invocation stack unless | 
 | 642 |    there is a :keyword:`finally` clause which happens to raise another | 
 | 643 |    exception. That new exception causes the old one to be lost. | 
| Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 644 |  | 
| Georg Brandl | f43713f | 2009-10-22 16:08:10 +0000 | [diff] [blame] | 645 | .. [#] Currently, control "flows off the end" except in the case of an exception | 
 | 646 |    or the execution of a :keyword:`return`, :keyword:`continue`, or | 
 | 647 |    :keyword:`break` statement. | 
| Georg Brandl | 3dbca81 | 2008-07-23 16:10:53 +0000 | [diff] [blame] | 648 |  | 
 | 649 | .. [#] A string literal appearing as the first statement in the function body is | 
 | 650 |    transformed into the function's ``__doc__`` attribute and therefore the | 
 | 651 |    function's :term:`docstring`. | 
 | 652 |  | 
 | 653 | .. [#] A string literal appearing as the first statement in the class body is | 
 | 654 |    transformed into the namespace's ``__doc__`` item and therefore the class's | 
 | 655 |    :term:`docstring`. |