Skip to main content
Help us improve PyPI by participating in user testing. All experience levels needed!

To avoid NoneType AttributeError exception on chained attributes

Project description

When you access an object with chained attributes

info = obj.a.b.c.d or 'Unknown'

Usually, it will failed when one intermediate attribute return ‘None‘

if obj.a returns None
obj.a.b.c.d will fail with that exception :
AttributeError: 'NoneType' object has no attribute 'b'

To avoid that, instead of returning a ‘None‘ value, one should return ‘NoAttr‘, by this way, even next chained attribute will return ‘NoAttr‘

if obj.a returns NoAttr
obj.a.b.c.d will not fail and will return NoAttr

‘NoAttr‘ can be seen as False, 0, ‘’, [] or {} depending on the context, so

if obj.a returns NoAttr

obj.a.b.c.d or 'Unknown' will return 'Unknown'

for i in obj.a.b.c.d:
    print i
prints nothing

obj.a.b.c.d + 1 returns 1

obj.a.b.c.d.anyfunc() returns NoAttr

but for ljust(), rjust(), rfind(), find(), rindex(), index(), count()
NoAttr is seen as '' :

obj.a.b.c.d.ljust(3) returns '   '

News

0.0.6 (2016-03-11)

remove __or__ and __rshift__ definition for python_textops

0.0.5 (2015-10-13)

add as_list property

0.0.4 (2015-08-19)

add __setattr__ to avoid any modification

0.0.3 (2015-07-27)

First official version

Project details


Release history Release notifications

This version
History Node

0.0.6

History Node

0.0.5

History Node

0.0.4

History Node

0.0.3

History Node

0.0.2

History Node

0.0.1

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Filename, size & hash SHA256 hash help File type Python version Upload date
noattr-0.0.6.tar.gz (2.4 kB) Copy SHA256 hash SHA256 Source None Mar 11, 2016

Supported by

Elastic Elastic Search Pingdom Pingdom Monitoring Google Google BigQuery Sentry Sentry Error logging CloudAMQP CloudAMQP RabbitMQ AWS AWS Cloud computing Fastly Fastly CDN DigiCert DigiCert EV certificate StatusPage StatusPage Status page