mirror of
				https://github.com/python/cpython.git
				synced 2025-10-25 02:43:41 +00:00 
			
		
		
		
	 f07d0026da
			
		
	
	
		f07d0026da
		
	
	
	
	
		
			
			svn+ssh://pythondev@svn.python.org/python/trunk ........ r70342 | georg.brandl | 2009-03-13 14:03:58 -0500 (Fri, 13 Mar 2009) | 1 line #5486: typos. ........ r70385 | benjamin.peterson | 2009-03-15 09:38:55 -0500 (Sun, 15 Mar 2009) | 1 line fix tuple.index() error message #5495 ........ r70386 | georg.brandl | 2009-03-15 16:32:06 -0500 (Sun, 15 Mar 2009) | 1 line #5496: fix docstring of lookup(). ........ r70387 | georg.brandl | 2009-03-15 16:37:16 -0500 (Sun, 15 Mar 2009) | 1 line #5493: clarify __nonzero__ docs. ........ r70389 | georg.brandl | 2009-03-15 16:43:38 -0500 (Sun, 15 Mar 2009) | 1 line Fix a small nit in the error message if bool() falls back on __len__ and it returns the wrong type: it would tell the user that __nonzero__ should return bool or int. ........ r70390 | georg.brandl | 2009-03-15 16:44:43 -0500 (Sun, 15 Mar 2009) | 1 line #5491: clarify nested() semantics. ........ r70392 | georg.brandl | 2009-03-15 16:46:00 -0500 (Sun, 15 Mar 2009) | 1 line #5488: add missing struct member. ........ r70393 | georg.brandl | 2009-03-15 16:47:42 -0500 (Sun, 15 Mar 2009) | 1 line #5478: fix copy-paste oversight in function signature. ........ r70395 | georg.brandl | 2009-03-15 16:51:48 -0500 (Sun, 15 Mar 2009) | 1 line #5276: document IDLESTARTUP and .Idle.py. ........ r70400 | georg.brandl | 2009-03-15 16:59:37 -0500 (Sun, 15 Mar 2009) | 3 lines Fix markup in re docs and give a mail address in regex howto, so that the recommendation to send suggestions to the author can be followed. ........ r70405 | georg.brandl | 2009-03-15 17:11:07 -0500 (Sun, 15 Mar 2009) | 7 lines Move the previously local import of threading to module level. This is cleaner and avoids lockups in obscure cases where a Queue is instantiated while the import lock is already held by another thread. OKed by Tim Peters. ........ r70406 | hirokazu.yamamoto | 2009-03-15 17:43:14 -0500 (Sun, 15 Mar 2009) | 1 line Added skip for old MSVC. ........ r70418 | georg.brandl | 2009-03-16 14:42:03 -0500 (Mon, 16 Mar 2009) | 1 line Add token markup. ........ r70438 | benjamin.peterson | 2009-03-17 15:29:51 -0500 (Tue, 17 Mar 2009) | 1 line I thought this was begging for an example ........ r70464 | benjamin.peterson | 2009-03-18 15:58:09 -0500 (Wed, 18 Mar 2009) | 1 line a much better example ........ r70468 | benjamin.peterson | 2009-03-18 22:04:31 -0500 (Wed, 18 Mar 2009) | 1 line close files after comparing them ........
		
			
				
	
	
		
			117 lines
		
	
	
	
		
			3.9 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
			
		
		
	
	
			117 lines
		
	
	
	
		
			3.9 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
| 
 | |
| :mod:`contextlib` --- Utilities for :keyword:`with`\ -statement contexts.
 | |
| =========================================================================
 | |
| 
 | |
| .. module:: contextlib
 | |
|    :synopsis: Utilities for with-statement contexts.
 | |
| 
 | |
| 
 | |
| This module provides utilities for common tasks involving the :keyword:`with`
 | |
| statement. For more information see also :ref:`typecontextmanager` and
 | |
| :ref:`context-managers`.
 | |
| 
 | |
| Functions provided:
 | |
| 
 | |
| 
 | |
| .. function:: contextmanager(func)
 | |
| 
 | |
|    This function is a :term:`decorator` that can be used to define a factory
 | |
|    function for :keyword:`with` statement context managers, without needing to
 | |
|    create a class or separate :meth:`__enter__` and :meth:`__exit__` methods.
 | |
| 
 | |
|    A simple example (this is not recommended as a real way of generating HTML!)::
 | |
| 
 | |
|       from contextlib import contextmanager
 | |
| 
 | |
|       @contextmanager
 | |
|       def tag(name):
 | |
|           print("<%s>" % name)
 | |
|           yield
 | |
|           print("</%s>" % name)
 | |
| 
 | |
|       >>> with tag("h1"):
 | |
|       ...    print("foo")
 | |
|       ...
 | |
|       <h1>
 | |
|       foo
 | |
|       </h1>
 | |
| 
 | |
|    The function being decorated must return a :term:`generator`-iterator when
 | |
|    called. This iterator must yield exactly one value, which will be bound to
 | |
|    the targets in the :keyword:`with` statement's :keyword:`as` clause, if any.
 | |
| 
 | |
|    At the point where the generator yields, the block nested in the :keyword:`with`
 | |
|    statement is executed.  The generator is then resumed after the block is exited.
 | |
|    If an unhandled exception occurs in the block, it is reraised inside the
 | |
|    generator at the point where the yield occurred.  Thus, you can use a
 | |
|    :keyword:`try`...\ :keyword:`except`...\ :keyword:`finally` statement to trap
 | |
|    the error (if any), or ensure that some cleanup takes place. If an exception is
 | |
|    trapped merely in order to log it or to perform some action (rather than to
 | |
|    suppress it entirely), the generator must reraise that exception. Otherwise the
 | |
|    generator context manager will indicate to the :keyword:`with` statement that
 | |
|    the exception has been handled, and execution will resume with the statement
 | |
|    immediately following the :keyword:`with` statement.
 | |
| 
 | |
| 
 | |
| .. function:: nested(mgr1[, mgr2[, ...]])
 | |
| 
 | |
|    Combine multiple context managers into a single nested context manager.
 | |
| 
 | |
|    Code like this::
 | |
| 
 | |
|       from contextlib import nested
 | |
| 
 | |
|       with nested(A(), B(), C()) as (X, Y, Z):
 | |
|           do_something()
 | |
| 
 | |
|    is equivalent to this::
 | |
| 
 | |
|       m1, m2, m3 = A(), B(), C()
 | |
|       with m1 as X:
 | |
|           with m2 as Y:
 | |
|               with m3 as Z:
 | |
|                   do_something()
 | |
| 
 | |
|    Note that if the :meth:`__exit__` method of one of the nested context managers
 | |
|    indicates an exception should be suppressed, no exception information will be
 | |
|    passed to any remaining outer context managers. Similarly, if the
 | |
|    :meth:`__exit__` method of one of the nested managers raises an exception, any
 | |
|    previous exception state will be lost; the new exception will be passed to the
 | |
|    :meth:`__exit__` methods of any remaining outer context managers. In general,
 | |
|    :meth:`__exit__` methods should avoid raising exceptions, and in particular they
 | |
|    should not re-raise a passed-in exception.
 | |
| 
 | |
| 
 | |
| .. function:: closing(thing)
 | |
| 
 | |
|    Return a context manager that closes *thing* upon completion of the block.  This
 | |
|    is basically equivalent to::
 | |
| 
 | |
|       from contextlib import contextmanager
 | |
| 
 | |
|       @contextmanager
 | |
|       def closing(thing):
 | |
|           try:
 | |
|               yield thing
 | |
|           finally:
 | |
|               thing.close()
 | |
| 
 | |
|    And lets you write code like this::
 | |
| 
 | |
|       from contextlib import closing
 | |
|       from urllib.request import urlopen
 | |
| 
 | |
|       with closing(urlopen('http://www.python.org')) as page:
 | |
|           for line in page:
 | |
|               print(line)
 | |
| 
 | |
|    without needing to explicitly close ``page``.  Even if an error occurs,
 | |
|    ``page.close()`` will be called when the :keyword:`with` block is exited.
 | |
| 
 | |
| 
 | |
| .. seealso::
 | |
| 
 | |
|    :pep:`0343` - The "with" statement
 | |
|       The specification, background, and examples for the Python :keyword:`with`
 | |
|       statement.
 | |
| 
 |