Using importlib
, what is the difference between \"Meta Path Finder\" (found by traversing over sys.meta_path) and Path Entry Finder\" (found by traversing over sys.
When a module is to be imported, the interpreter first walks through the list of objects in sys.meta_path
, calling the find_spec()
or (deprecated since 3.4) find_module()
method on each. )The interface is documented in the importlib.abc.MetaPathFinder abstract base class.) These are queried before any other importers (including frozen and built-in) are checked and so can override any other import processing.
The PathFinder
object in sys.meta_path
is what uses sys.path
and sys.path_hooks
. (Except in Python < 3.4 where the PathFinder
functionality is built in to the interpreter to be used when nothing in sys.meta_path
can load a module.)
The PathFinder
walks through the list of paths in sys.path
. For each path, if finder is not already cached for that path in sys.path_importer_cache
it walks through the list of callables in sys.path_hooks
, calling each one with the path to see if it will produce a finder; it caches the first one it finds in sys.path.importer_cache_
.
Once it's got the finder it queries that via the find_spec()
or deprecated find_module()
method to see if it can find that module. If so, it can continue on to import it, otherwise it starts the step above with the next path on sys.path
.
This was initially described in PEP 302, but PEP 451 is pretty much the modern behaviour; the importlib documentation appears to be the current spec.
There's considerably more detail summarized (with more links) in my personal notes.