You cannot select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
	
	
		
			41 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			Python
		
	
			
		
		
	
	
			41 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			Python
		
	
"""
 | 
						|
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])
 |