In Python 3.4 e versioni successive, è possibile importare direttamente da un file di origine (collegamento alla documentazione) . Questa non è la soluzione più semplice, ma sto includendo questa risposta per completezza.
Ecco un esempio Innanzitutto, il file da importare, denominato foo.py
:
def announce():
print("Imported!")
Il codice che importa il file sopra, fortemente ispirato all'esempio nella documentazione:
import importlib.util
def module_from_file(module_name, file_path):
spec = importlib.util.spec_from_file_location(module_name, file_path)
module = importlib.util.module_from_spec(spec)
spec.loader.exec_module(module)
return module
foo = module_from_file("foo", "/path/to/foo.py")
if __name__ == "__main__":
print(foo)
print(dir(foo))
foo.announce()
Il risultato:
<module 'foo' from '/path/to/foo.py'>
['__builtins__', '__cached__', '__doc__', '__file__', '__loader__', '__name__', '__package__', '__spec__', 'announce']
Imported!
Si noti che il nome della variabile, il nome del modulo e il nome file non devono necessariamente corrispondere. Questo codice funziona ancora:
import importlib.util
def module_from_file(module_name, file_path):
spec = importlib.util.spec_from_file_location(module_name, file_path)
module = importlib.util.module_from_spec(spec)
spec.loader.exec_module(module)
return module
baz = module_from_file("bar", "/path/to/foo.py")
if __name__ == "__main__":
print(baz)
print(dir(baz))
baz.announce()
Il risultato:
<module 'bar' from '/path/to/foo.py'>
['__builtins__', '__cached__', '__doc__', '__file__', '__loader__', '__name__', '__package__', '__spec__', 'announce']
Imported!
L'importazione a livello di codice dei moduli è stata introdotta in Python 3.1 e offre un maggiore controllo su come i moduli vengono importati. Fare riferimento alla documentazione per ulteriori informazioni.