| 12345678910111213141516171819202122232425262728293031323334353637383940 |
- """
- A simple utility to import something by its string name.
- Vendored form ipython_genutils
- """
- # Copyright (c) IPython Development Team.
- # Distributed under the terms of the Modified BSD License.
- from __future__ import annotations
- def import_item(name):
- """Import and return ``bar`` given the string ``foo.bar``.
- Calling ``bar = import_item("foo.bar")`` is the functional equivalent of
- executing the code ``from foo import bar``.
- Parameters
- ----------
- name : string
- The fully qualified name of the module/package being imported.
- Returns
- -------
- mod : module object
- The module that was imported.
- """
- parts = name.rsplit(".", 1)
- if len(parts) == 2:
- # called with 'foo.bar....'
- package, obj = parts
- module = __import__(package, fromlist=[obj])
- try:
- pak = getattr(module, obj)
- except AttributeError:
- raise ImportError("No module named %s" % obj) from None
- return pak
- # called with un-dotted string
- return __import__(parts[0])
|