Resolver for Python dotted names.
Project description
The zope.dottedname module provides one function, resolve that resolves strings containing dotted names into the appropriate python object.
Dotted names are resolved by importing modules and by getting attributes from imported modules. Names may be relative, provided the module they are relative to is supplied.
Here are some examples of importing absolute names:
>>> from zope.dottedname.resolve import resolve >>> resolve('unittest') <module 'unittest' from '...'> >>> resolve('datetime.datetime') <type 'datetime.datetime'> >>> resolve('datetime.datetime.now') <built-in method now of type object at ...> >>> resolve('non existent module') Traceback (most recent call last): ... ImportError: No module named non existent module >>> resolve('__doc__') Traceback (most recent call last): ... ImportError: No module named __doc__ >>> resolve('datetime.foo') Traceback (most recent call last): ... ImportError: No module named foo >>> resolve('os.path.split').__name__ 'split'
Here are some examples of importing relative names:
>>> resolve('.split', 'os.path') <function split at ...> >>> resolve('..system', 'os.path') <built-in function system> >>> resolve('...datetime', 'os.path') <module 'datetime' from '...'>
NB: When relative names are imported, a module the name is relative to must be supplied:
>>> resolve('.split').__name__ Traceback (most recent call last): ... ValueError: relative name without base module
CHANGES
3.4.4 (2009-01-27)
Fix ReST in README.txt, fix broken tests with recent zope.testing.
3.4.3 (2008-12-02)
More documentation and tests.
3.4.2 (2007-10-02)
Fix broken release.
3.4.1 (2007-10-02)
Updated package meta-data.
3.4.0 (2007-07-19)
Initial Zope-independent release.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.