importstring.py
47 lines
| 1.6 KiB
| text/x-python
|
PythonLexer
Brian Granger
|
r2229 | # encoding: utf-8 | ||
""" | ||||
A simple utility to import something by its string name. | ||||
Authors: | ||||
* Brian Granger | ||||
""" | ||||
#----------------------------------------------------------------------------- | ||||
Matthias BUSSONNIER
|
r5390 | # Copyright (C) 2008-2011 The IPython Development Team | ||
Brian Granger
|
r2229 | # | ||
# Distributed under the terms of the BSD License. The full license is in | ||||
# the file COPYING, distributed as part of this software. | ||||
#----------------------------------------------------------------------------- | ||||
#----------------------------------------------------------------------------- | ||||
# Functions and classes | ||||
#----------------------------------------------------------------------------- | ||||
def import_item(name): | ||||
"""Import and return bar given the string foo.bar.""" | ||||
package = '.'.join(name.split('.')[0:-1]) | ||||
obj = name.split('.')[-1] | ||||
Fernando Perez
|
r3121 | |||
# Note: the original code for this was the following. We've left it | ||||
# visible for now in case the new implementation shows any problems down | ||||
# the road, to make it easier on anyone looking for a problem. This code | ||||
# should be removed once we're comfortable we didn't break anything. | ||||
## execString = 'from %s import %s' % (package, obj) | ||||
## try: | ||||
## exec execString | ||||
## except SyntaxError: | ||||
## raise ImportError("Invalid class specification: %s" % name) | ||||
## exec 'temp = %s' % obj | ||||
## return temp | ||||
Thomas Kluyver
|
r3108 | if package: | ||
module = __import__(package,fromlist=[obj]) | ||||
Fernando Perez
|
r6738 | try: | ||
pak = module.__dict__[obj] | ||||
except KeyError: | ||||
raise ImportError('No module named %s' % obj) | ||||
return pak | ||||
Thomas Kluyver
|
r3108 | else: | ||
return __import__(obj) | ||||