diff options
author | Raymond Hettinger <python@rcn.com> | 2003-07-12 01:05:37 (GMT) |
---|---|---|
committer | Raymond Hettinger <python@rcn.com> | 2003-07-12 01:05:37 (GMT) |
commit | 6122d0267f37b2122a96fbe824efef3ae019266a (patch) | |
tree | 8a9e4e8b4a9e2e488d5438eb3e9c256c3dfd3e2d /Doc/tut | |
parent | cc39a13d6d661d297f937f35554b601f6b9efc04 (diff) | |
download | cpython-6122d0267f37b2122a96fbe824efef3ae019266a.zip cpython-6122d0267f37b2122a96fbe824efef3ae019266a.tar.gz cpython-6122d0267f37b2122a96fbe824efef3ae019266a.tar.bz2 |
SF patch #726751: Clarify docs for except target assignment
Brett found that the tutorial didn't really explain what was happening
with exception targets. Hopefully, this sheds some light on the subject.
Diffstat (limited to 'Doc/tut')
-rw-r--r-- | Doc/tut/tut.tex | 28 |
1 files changed, 20 insertions, 8 deletions
diff --git a/Doc/tut/tut.tex b/Doc/tut/tut.tex index 05a8ea6..cffbf23 100644 --- a/Doc/tut/tut.tex +++ b/Doc/tut/tut.tex @@ -3318,17 +3318,29 @@ by the \keyword{try} \ldots\ \keyword{except} statement. When an exception occurs, it may have an associated value, also known as the exception's \emph{argument}. The presence and type of the argument depend on the exception type. -For exception types which have an argument, the except clause may -specify a variable after the exception name (or list) to receive the -argument's value, as follows: + +The except clause may specify a variable after the exception name (or list). +The variable is bound to an exception instance with the arguments stored +in \code{instance.args}. For convenience, the exception instance +defines \method{__getitem__} and \method{__str__} so the arguments can +be accessed or printed directly without having to reference \code{.args}. \begin{verbatim} >>> try: -... spam() -... except NameError, x: -... print 'name', x, 'undefined' -... -name spam undefined +... raise Exception('spam', 'eggs') +... except Exception, inst: +... print type(inst) # the exception instance +... print inst.args # arguments stored in .args +... print inst # __str__ allows args to printed directly +... x, y = inst # __getitem__ allows args to be unpacked directly +... print 'x =', x +... print 'y =', y +... +<type 'instance'> +('spam', 'eggs') +('spam', 'eggs') +x = spam +y = eggs \end{verbatim} If an exception has an argument, it is printed as the last part |