Groups | Search | Server Info | Keyboard shortcuts | Login | Register [http] [https] [nntp] [nntps]


Groups > comp.lang.python > #26369

Re: NameError vs AttributeError

Date 2012-08-01 08:53 -0700
From Ethan Furman <ethan@stoneleaf.us>
Subject Re: NameError vs AttributeError
References <u1pke9-a46.ln1@satorlaser.homedns.org> <jv9eo7$jit$1@dough.gmane.org> <CALvWhxv8ww08AW_+N7K=XLnqOAz6Bmtd80M8qAeb3r4RCCm-8Q@mail.gmail.com> <jv9sce$lgm$1@dough.gmane.org>
Newsgroups comp.lang.python
Message-ID <mailman.2836.1343838883.4697.python-list@python.org> (permalink)

Show all headers | View raw


Terry Reedy wrote:
> On 7/31/2012 4:49 PM, Chris Kaynor wrote:
>> On Tue, Jul 31, 2012 at 1:21 PM, Terry Reedy wrote:
>>> Another example: KeyError and IndexError are both subscript errors,
>>> but there is no SubscriptError superclass, even though both work
>>> thru the same mechanism -- __getitem__.  The reason is that there is
>>> no need for one. In 'x[y]', x is usually intented to be either a
>>> sequence or mapping, but not possibly both. In the rare cases when
>>> one wants to catch both errors, one can easily enough. To continue
>>> the example above, popping an empty list and empty set produce
>>> IndexError and KeyError respectively:
>>>
>>>    try:
>>>      while True:
>>>        process(pop())
>>>    except (KeyError, IndexError):
>>>      pass  # empty collection means we are done
>>>
>> There is a base type for KeyError and IndexError: LookupError.
>>
>> http://docs.python.org/library/exceptions.html#exception-hierarchy
> 
> Oh, so there is. Added in 1.5 strictly as a never-directly-raised base 
> class for the above pair, now also directly raised in codecs.lookup. I 
> have not decided if I want to replace the tuple in the code in my book.

I think I'd stick with the tuple -- LookupError could just as easily 
encompass NameError and AttributeError.

Back to comp.lang.python | Previous | NextPrevious in thread | Next in thread | Find similar | Unroll thread


Thread

NameError vs AttributeError Ulrich Eckhardt <ulrich.eckhardt@dominolaser.com> - 2012-07-31 12:36 +0200
  Re: NameError vs AttributeError Terry Reedy <tjreedy@udel.edu> - 2012-07-31 16:21 -0400
  Re: NameError vs AttributeError Terry Reedy <tjreedy@udel.edu> - 2012-07-31 20:14 -0400
  Re: NameError vs AttributeError Ethan Furman <ethan@stoneleaf.us> - 2012-08-01 08:53 -0700
  Re: NameError vs AttributeError Terry Reedy <tjreedy@udel.edu> - 2012-08-01 12:59 -0400

csiph-web