[Python-Dev] cpython: Rename contextlib.ignored() to contextlib.ignore().

Victor Stinner victor.stinner at gmail.com
Wed Oct 16 13:42:34 CEST 2013


I might agree with idea of contextlib.ignore() (I'm still opposed to
the idea), but I don't understand the purpose of adding a new syntax
doing exactly the same than try/except:

>     with trap(OSError) as cm:
>         os.unlink('missing.txt')
>     if cm.exc:
>         do_something()

Nobody noticed that this can be written:

try:
  os.unlink('missing.txt')
except OSError as err:
  # do something with err

?? What happened with the Zen Principle "There should be one-- and
preferably only one --obvious way to do it." I don't understand why I
would import contextlib and use a new context manager, whereas
try/except is already a builtin feature of Python.

By the way, what are the performances of contextlib.ignore()?
Exceptions can be slow in some cases. Adding something even slower
would not be a good idea.

Victor


2013/10/15 Tim Delaney <timothy.c.delaney at gmail.com>:
> On 16 October 2013 05:17, Alexander Belopolsky
> <alexander.belopolsky at gmail.com> wrote:
>>
>> On Tue, Oct 15, 2013 at 12:45 PM, Ethan Furman <ethan at stoneleaf.us> wrote:
>> >     with trap(OSError) as cm:
>> >         os.unlink('missing.txt')
>> >     if cm.exc:
>> >         do_something()
>>
>> .. and why is this better than
>>
>> try:
>>    os.unlink('missing.txt')
>> except OSError as exc:
>>    do_something()
>
>
> It would allow you to perform a series of operations then process the any
> exceptions all together e.g.
>
> with trap(OSError) as cm1:
>     os.unlink('missing.txt')
>
> with trap(OSError) as cm2:
>     os.unlink('other_missing.txt')
>
> with trap(OSError) as cm3:
>     os.unlink('another_missing.txt')
>
> for cm in (cm1, cm2, cm3):
>     if cm.exc:
>         do_something(cm.exc)
>
> An equivalent implementation would be:
>
> exceptions = []
>
> try:
>     os.unlink('missing.txt')
> except OSError as exc:
>     exceptions.append(exc)
>
> try:
>     os.unlink('missing.txt')
> except OSError as exc:
>     exceptions.append(exc)
>
> try:
>     os.unlink('missing.txt')
> except OSError as exc:
>     exceptions.append(exc)
>
> for exc in exceptions:
>     if exc:
>         do_something(exc)
>
> Tim Delaney
>
> _______________________________________________
> Python-Dev mailing list
> Python-Dev at python.org
> https://mail.python.org/mailman/listinfo/python-dev
> Unsubscribe:
> https://mail.python.org/mailman/options/python-dev/victor.stinner%40gmail.com
>


More information about the Python-Dev mailing list