0x1949 Team - FAZEMRX - MANAGER
Edit File: imputil.html
<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" /> <title>31.3. imputil — Import utilities — Python 2.7.18 documentation</title> <link rel="stylesheet" type="text/css" href="../_static/pygments.css" /> <link rel="stylesheet" type="text/css" href="../_static/classic.css" /> <script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script> <script src="../_static/jquery.js"></script> <script src="../_static/underscore.js"></script> <script src="../_static/doctools.js"></script> <script src="../_static/sidebar.js"></script> <link rel="search" type="application/opensearchdescription+xml" title="Search within Python 2.7.18 documentation" href="../_static/opensearch.xml"/> <link rel="author" title="About these documents" href="../about.html" /> <link rel="index" title="Index" href="../genindex.html" /> <link rel="search" title="Search" href="../search.html" /> <link rel="copyright" title="Copyright" href="../copyright.html" /> <link rel="next" title="31.4. zipimport — Import modules from Zip archives" href="zipimport.html" /> <link rel="prev" title="31.2. importlib — Convenience wrappers for __import__()" href="importlib.html" /> <link rel="shortcut icon" type="image/png" href="../_static/py.png" /> <link rel="canonical" href="file:///usr/share/doc/python2.7/html/library/imputil.html" /> <script type="text/javascript" src="../_static/copybutton.js"></script> </head><body> <div id="outdated-warning" style="padding: .5em; text-align: center; background-color: #FFBABA; color: #6A0E0E;"> This document is for an old version of Python that is <a href="https://devguide.python.org/devcycle/#end-of-life-branches">no longer supported</a>. You should install the python3 and python3-doc packages and read the <a href="file:///usr/share/doc/python3-doc/html/library/imputil.html"> Python documentation for the Python3 version packaged in this release</a>. </div> <div class="related" role="navigation" aria-label="related navigation"> <h3>Navigation</h3> <ul> <li class="right" style="margin-right: 10px"> <a href="../genindex.html" title="General Index" accesskey="I">index</a></li> <li class="right" > <a href="../py-modindex.html" title="Python Module Index" >modules</a> |</li> <li class="right" > <a href="zipimport.html" title="31.4. zipimport — Import modules from Zip archives" accesskey="N">next</a> |</li> <li class="right" > <a href="importlib.html" title="31.2. importlib — Convenience wrappers for __import__()" accesskey="P">previous</a> |</li> <li><img src="../_static/py.png" alt="" style="vertical-align: middle; margin-top: -1px"/></li> <li><a href="https://www.python.org/">Python</a> »</li> <li> <a href="../index.html">Python 2.7.18 documentation</a> » </li> <li class="nav-item nav-item-1"><a href="index.html" >The Python Standard Library</a> »</li> <li class="nav-item nav-item-2"><a href="modules.html" accesskey="U"><span class="section-number">31. </span>Importing Modules</a> »</li> <li class="nav-item nav-item-this"><a href=""><span class="section-number">31.3. </span><code class="xref py py-mod docutils literal notranslate"><span class="pre">imputil</span></code> — Import utilities</a></li> </ul> </div> <div class="document"> <div class="documentwrapper"> <div class="bodywrapper"> <div class="body" role="main"> <section id="module-imputil"> <span id="imputil-import-utilities"></span><h1><span class="section-number">31.3. </span><a class="reference internal" href="#module-imputil" title="imputil: Manage and augment the import process. (deprecated)"><code class="xref py py-mod docutils literal notranslate"><span class="pre">imputil</span></code></a> — Import utilities<a class="headerlink" href="#module-imputil" title="Permalink to this headline">¶</a></h1> <div class="deprecated"> <p><span class="versionmodified deprecated">Deprecated since version 2.6: </span>The <a class="reference internal" href="#module-imputil" title="imputil: Manage and augment the import process. (deprecated)"><code class="xref py py-mod docutils literal notranslate"><span class="pre">imputil</span></code></a> module has been removed in Python 3.</p> </div> <p id="index-0">This module provides a very handy and useful mechanism for custom <a class="reference internal" href="../reference/simple_stmts.html#import"><code class="xref std std-keyword docutils literal notranslate"><span class="pre">import</span></code></a> hooks. Compared to the older <code class="xref py py-mod docutils literal notranslate"><span class="pre">ihooks</span></code> module, <a class="reference internal" href="#module-imputil" title="imputil: Manage and augment the import process. (deprecated)"><code class="xref py py-mod docutils literal notranslate"><span class="pre">imputil</span></code></a> takes a dramatically simpler and more straight-forward approach to custom <a class="reference internal" href="../reference/simple_stmts.html#import"><code class="xref std std-keyword docutils literal notranslate"><span class="pre">import</span></code></a> functions.</p> <dl class="py class"> <dt class="sig sig-object py" id="imputil.ImportManager"> <em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">imputil.</span></span><span class="sig-name descname"><span class="pre">ImportManager</span></span><span class="sig-paren">(</span><span class="optional">[</span><em class="sig-param"><span class="n"><span class="pre">fs_imp</span></span></em><span class="optional">]</span><span class="sig-paren">)</span><a class="headerlink" href="#imputil.ImportManager" title="Permalink to this definition">¶</a></dt> <dd><p>Manage the import process.</p> <dl class="py method"> <dt class="sig sig-object py" id="imputil.ImportManager.install"> <span class="sig-name descname"><span class="pre">install</span></span><span class="sig-paren">(</span><span class="optional">[</span><em class="sig-param"><span class="n"><span class="pre">namespace</span></span></em><span class="optional">]</span><span class="sig-paren">)</span><a class="headerlink" href="#imputil.ImportManager.install" title="Permalink to this definition">¶</a></dt> <dd><p>Install this ImportManager into the specified namespace.</p> </dd></dl> <dl class="py method"> <dt class="sig sig-object py" id="imputil.ImportManager.uninstall"> <span class="sig-name descname"><span class="pre">uninstall</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="headerlink" href="#imputil.ImportManager.uninstall" title="Permalink to this definition">¶</a></dt> <dd><p>Restore the previous import mechanism.</p> </dd></dl> <dl class="py method"> <dt class="sig sig-object py" id="imputil.ImportManager.add_suffix"> <span class="sig-name descname"><span class="pre">add_suffix</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">suffix</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">importFunc</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#imputil.ImportManager.add_suffix" title="Permalink to this definition">¶</a></dt> <dd><p>Undocumented.</p> </dd></dl> </dd></dl> <dl class="py class"> <dt class="sig sig-object py" id="imputil.Importer"> <em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">imputil.</span></span><span class="sig-name descname"><span class="pre">Importer</span></span><a class="headerlink" href="#imputil.Importer" title="Permalink to this definition">¶</a></dt> <dd><p>Base class for replacing standard import functions.</p> <dl class="py method"> <dt class="sig sig-object py" id="imputil.Importer.import_top"> <span class="sig-name descname"><span class="pre">import_top</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">name</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#imputil.Importer.import_top" title="Permalink to this definition">¶</a></dt> <dd><p>Import a top-level module.</p> </dd></dl> <dl class="py method"> <dt class="sig sig-object py" id="imputil.Importer.get_code"> <span class="sig-name descname"><span class="pre">get_code</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">parent</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">modname</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">fqname</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#imputil.Importer.get_code" title="Permalink to this definition">¶</a></dt> <dd><p>Find and retrieve the code for the given module.</p> <p><em>parent</em> specifies a parent module to define a context for importing. It may be <code class="docutils literal notranslate"><span class="pre">None</span></code>, indicating no particular context for the search.</p> <p><em>modname</em> specifies a single module (not dotted) within the parent.</p> <p><em>fqname</em> specifies the fully-qualified module name. This is a (potentially) dotted name from the “root” of the module namespace down to the modname.</p> <p>If there is no parent, then modname==fqname.</p> <p>This method should return <code class="docutils literal notranslate"><span class="pre">None</span></code>, or a 3-tuple.</p> <blockquote> <div><ul class="simple"> <li><p>If the module was not found, then <code class="docutils literal notranslate"><span class="pre">None</span></code> should be returned.</p></li> <li><p>The first item of the 2- or 3-tuple should be the integer 0 or 1, specifying whether the module that was found is a package or not.</p></li> <li><p>The second item is the code object for the module (it will be executed within the new module’s namespace). This item can also be a fully-loaded module object (e.g. loaded from a shared lib).</p></li> <li><p>The third item is a dictionary of name/value pairs that will be inserted into new module before the code object is executed. This is provided in case the module’s code expects certain values (such as where the module was found). When the second item is a module object, then these names/values will be inserted <em>after</em> the module has been loaded/initialized.</p></li> </ul> </div></blockquote> </dd></dl> </dd></dl> <dl class="py class"> <dt class="sig sig-object py" id="imputil.BuiltinImporter"> <em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">imputil.</span></span><span class="sig-name descname"><span class="pre">BuiltinImporter</span></span><a class="headerlink" href="#imputil.BuiltinImporter" title="Permalink to this definition">¶</a></dt> <dd><p>Emulate the import mechanism for built-in and frozen modules. This is a sub-class of the <a class="reference internal" href="#imputil.Importer" title="imputil.Importer"><code class="xref py py-class docutils literal notranslate"><span class="pre">Importer</span></code></a> class.</p> <dl class="py method"> <dt class="sig sig-object py" id="imputil.BuiltinImporter.get_code"> <span class="sig-name descname"><span class="pre">get_code</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">parent</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">modname</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">fqname</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#imputil.BuiltinImporter.get_code" title="Permalink to this definition">¶</a></dt> <dd><p>Undocumented.</p> </dd></dl> </dd></dl> <dl class="py function"> <dt class="sig sig-object py" id="imputil.py_suffix_importer"> <span class="sig-prename descclassname"><span class="pre">imputil.</span></span><span class="sig-name descname"><span class="pre">py_suffix_importer</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">filename</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">finfo</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">fqname</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#imputil.py_suffix_importer" title="Permalink to this definition">¶</a></dt> <dd><p>Undocumented.</p> </dd></dl> <dl class="py class"> <dt class="sig sig-object py" id="imputil.DynLoadSuffixImporter"> <em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">imputil.</span></span><span class="sig-name descname"><span class="pre">DynLoadSuffixImporter</span></span><span class="sig-paren">(</span><span class="optional">[</span><em class="sig-param"><span class="n"><span class="pre">desc</span></span></em><span class="optional">]</span><span class="sig-paren">)</span><a class="headerlink" href="#imputil.DynLoadSuffixImporter" title="Permalink to this definition">¶</a></dt> <dd><p>Undocumented.</p> <dl class="py method"> <dt class="sig sig-object py" id="imputil.DynLoadSuffixImporter.import_file"> <span class="sig-name descname"><span class="pre">import_file</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">filename</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">finfo</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">fqname</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#imputil.DynLoadSuffixImporter.import_file" title="Permalink to this definition">¶</a></dt> <dd><p>Undocumented.</p> </dd></dl> </dd></dl> <section id="examples"> <span id="examples-imputil"></span><h2><span class="section-number">31.3.1. </span>Examples<a class="headerlink" href="#examples" title="Permalink to this headline">¶</a></h2> <p>This is a re-implementation of hierarchical module import.</p> <p>This code is intended to be read, not executed. However, it does work – all you need to do to enable it is “import knee”.</p> <p>(The name is a pun on the clunkier predecessor of this module, “ni”.)</p> <div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="kn">import</span> <span class="nn">sys</span><span class="o">,</span> <span class="nn">imp</span><span class="o">,</span> <span class="nn">__builtin__</span> <span class="c1"># Replacement for __import__()</span> <span class="k">def</span> <span class="nf">import_hook</span><span class="p">(</span><span class="n">name</span><span class="p">,</span> <span class="nb">globals</span><span class="o">=</span><span class="kc">None</span><span class="p">,</span> <span class="nb">locals</span><span class="o">=</span><span class="kc">None</span><span class="p">,</span> <span class="n">fromlist</span><span class="o">=</span><span class="kc">None</span><span class="p">):</span> <span class="n">parent</span> <span class="o">=</span> <span class="n">determine_parent</span><span class="p">(</span><span class="nb">globals</span><span class="p">)</span> <span class="n">q</span><span class="p">,</span> <span class="n">tail</span> <span class="o">=</span> <span class="n">find_head_package</span><span class="p">(</span><span class="n">parent</span><span class="p">,</span> <span class="n">name</span><span class="p">)</span> <span class="n">m</span> <span class="o">=</span> <span class="n">load_tail</span><span class="p">(</span><span class="n">q</span><span class="p">,</span> <span class="n">tail</span><span class="p">)</span> <span class="k">if</span> <span class="ow">not</span> <span class="n">fromlist</span><span class="p">:</span> <span class="k">return</span> <span class="n">q</span> <span class="k">if</span> <span class="nb">hasattr</span><span class="p">(</span><span class="n">m</span><span class="p">,</span> <span class="s2">"__path__"</span><span class="p">):</span> <span class="n">ensure_fromlist</span><span class="p">(</span><span class="n">m</span><span class="p">,</span> <span class="n">fromlist</span><span class="p">)</span> <span class="k">return</span> <span class="n">m</span> <span class="k">def</span> <span class="nf">determine_parent</span><span class="p">(</span><span class="nb">globals</span><span class="p">):</span> <span class="k">if</span> <span class="ow">not</span> <span class="nb">globals</span> <span class="ow">or</span> <span class="ow">not</span> <span class="nb">globals</span><span class="o">.</span><span class="n">has_key</span><span class="p">(</span><span class="s2">"__name__"</span><span class="p">):</span> <span class="k">return</span> <span class="kc">None</span> <span class="n">pname</span> <span class="o">=</span> <span class="nb">globals</span><span class="p">[</span><span class="s1">'__name__'</span><span class="p">]</span> <span class="k">if</span> <span class="nb">globals</span><span class="o">.</span><span class="n">has_key</span><span class="p">(</span><span class="s2">"__path__"</span><span class="p">):</span> <span class="n">parent</span> <span class="o">=</span> <span class="n">sys</span><span class="o">.</span><span class="n">modules</span><span class="p">[</span><span class="n">pname</span><span class="p">]</span> <span class="k">assert</span> <span class="nb">globals</span> <span class="ow">is</span> <span class="n">parent</span><span class="o">.</span><span class="vm">__dict__</span> <span class="k">return</span> <span class="n">parent</span> <span class="k">if</span> <span class="s1">'.'</span> <span class="ow">in</span> <span class="n">pname</span><span class="p">:</span> <span class="n">i</span> <span class="o">=</span> <span class="n">pname</span><span class="o">.</span><span class="n">rfind</span><span class="p">(</span><span class="s1">'.'</span><span class="p">)</span> <span class="n">pname</span> <span class="o">=</span> <span class="n">pname</span><span class="p">[:</span><span class="n">i</span><span class="p">]</span> <span class="n">parent</span> <span class="o">=</span> <span class="n">sys</span><span class="o">.</span><span class="n">modules</span><span class="p">[</span><span class="n">pname</span><span class="p">]</span> <span class="k">assert</span> <span class="n">parent</span><span class="o">.</span><span class="vm">__name__</span> <span class="o">==</span> <span class="n">pname</span> <span class="k">return</span> <span class="n">parent</span> <span class="k">return</span> <span class="kc">None</span> <span class="k">def</span> <span class="nf">find_head_package</span><span class="p">(</span><span class="n">parent</span><span class="p">,</span> <span class="n">name</span><span class="p">):</span> <span class="k">if</span> <span class="s1">'.'</span> <span class="ow">in</span> <span class="n">name</span><span class="p">:</span> <span class="n">i</span> <span class="o">=</span> <span class="n">name</span><span class="o">.</span><span class="n">find</span><span class="p">(</span><span class="s1">'.'</span><span class="p">)</span> <span class="n">head</span> <span class="o">=</span> <span class="n">name</span><span class="p">[:</span><span class="n">i</span><span class="p">]</span> <span class="n">tail</span> <span class="o">=</span> <span class="n">name</span><span class="p">[</span><span class="n">i</span><span class="o">+</span><span class="mi">1</span><span class="p">:]</span> <span class="k">else</span><span class="p">:</span> <span class="n">head</span> <span class="o">=</span> <span class="n">name</span> <span class="n">tail</span> <span class="o">=</span> <span class="s2">""</span> <span class="k">if</span> <span class="n">parent</span><span class="p">:</span> <span class="n">qname</span> <span class="o">=</span> <span class="s2">"</span><span class="si">%s</span><span class="s2">.</span><span class="si">%s</span><span class="s2">"</span> <span class="o">%</span> <span class="p">(</span><span class="n">parent</span><span class="o">.</span><span class="vm">__name__</span><span class="p">,</span> <span class="n">head</span><span class="p">)</span> <span class="k">else</span><span class="p">:</span> <span class="n">qname</span> <span class="o">=</span> <span class="n">head</span> <span class="n">q</span> <span class="o">=</span> <span class="n">import_module</span><span class="p">(</span><span class="n">head</span><span class="p">,</span> <span class="n">qname</span><span class="p">,</span> <span class="n">parent</span><span class="p">)</span> <span class="k">if</span> <span class="n">q</span><span class="p">:</span> <span class="k">return</span> <span class="n">q</span><span class="p">,</span> <span class="n">tail</span> <span class="k">if</span> <span class="n">parent</span><span class="p">:</span> <span class="n">qname</span> <span class="o">=</span> <span class="n">head</span> <span class="n">parent</span> <span class="o">=</span> <span class="kc">None</span> <span class="n">q</span> <span class="o">=</span> <span class="n">import_module</span><span class="p">(</span><span class="n">head</span><span class="p">,</span> <span class="n">qname</span><span class="p">,</span> <span class="n">parent</span><span class="p">)</span> <span class="k">if</span> <span class="n">q</span><span class="p">:</span> <span class="k">return</span> <span class="n">q</span><span class="p">,</span> <span class="n">tail</span> <span class="k">raise</span> <span class="ne">ImportError</span><span class="p">(</span><span class="s2">"No module named "</span> <span class="o">+</span> <span class="n">qname</span><span class="p">)</span> <span class="k">def</span> <span class="nf">load_tail</span><span class="p">(</span><span class="n">q</span><span class="p">,</span> <span class="n">tail</span><span class="p">):</span> <span class="n">m</span> <span class="o">=</span> <span class="n">q</span> <span class="k">while</span> <span class="n">tail</span><span class="p">:</span> <span class="n">i</span> <span class="o">=</span> <span class="n">tail</span><span class="o">.</span><span class="n">find</span><span class="p">(</span><span class="s1">'.'</span><span class="p">)</span> <span class="k">if</span> <span class="n">i</span> <span class="o"><</span> <span class="mi">0</span><span class="p">:</span> <span class="n">i</span> <span class="o">=</span> <span class="nb">len</span><span class="p">(</span><span class="n">tail</span><span class="p">)</span> <span class="n">head</span><span class="p">,</span> <span class="n">tail</span> <span class="o">=</span> <span class="n">tail</span><span class="p">[:</span><span class="n">i</span><span class="p">],</span> <span class="n">tail</span><span class="p">[</span><span class="n">i</span><span class="o">+</span><span class="mi">1</span><span class="p">:]</span> <span class="n">mname</span> <span class="o">=</span> <span class="s2">"</span><span class="si">%s</span><span class="s2">.</span><span class="si">%s</span><span class="s2">"</span> <span class="o">%</span> <span class="p">(</span><span class="n">m</span><span class="o">.</span><span class="vm">__name__</span><span class="p">,</span> <span class="n">head</span><span class="p">)</span> <span class="n">m</span> <span class="o">=</span> <span class="n">import_module</span><span class="p">(</span><span class="n">head</span><span class="p">,</span> <span class="n">mname</span><span class="p">,</span> <span class="n">m</span><span class="p">)</span> <span class="k">if</span> <span class="ow">not</span> <span class="n">m</span><span class="p">:</span> <span class="k">raise</span> <span class="ne">ImportError</span><span class="p">(</span><span class="s2">"No module named "</span> <span class="o">+</span> <span class="n">mname</span><span class="p">)</span> <span class="k">return</span> <span class="n">m</span> <span class="k">def</span> <span class="nf">ensure_fromlist</span><span class="p">(</span><span class="n">m</span><span class="p">,</span> <span class="n">fromlist</span><span class="p">,</span> <span class="n">recursive</span><span class="o">=</span><span class="mi">0</span><span class="p">):</span> <span class="k">for</span> <span class="n">sub</span> <span class="ow">in</span> <span class="n">fromlist</span><span class="p">:</span> <span class="k">if</span> <span class="n">sub</span> <span class="o">==</span> <span class="s2">"*"</span><span class="p">:</span> <span class="k">if</span> <span class="ow">not</span> <span class="n">recursive</span><span class="p">:</span> <span class="k">try</span><span class="p">:</span> <span class="nb">all</span> <span class="o">=</span> <span class="n">m</span><span class="o">.</span><span class="n">__all__</span> <span class="k">except</span> <span class="ne">AttributeError</span><span class="p">:</span> <span class="k">pass</span> <span class="k">else</span><span class="p">:</span> <span class="n">ensure_fromlist</span><span class="p">(</span><span class="n">m</span><span class="p">,</span> <span class="nb">all</span><span class="p">,</span> <span class="mi">1</span><span class="p">)</span> <span class="k">continue</span> <span class="k">if</span> <span class="n">sub</span> <span class="o">!=</span> <span class="s2">"*"</span> <span class="ow">and</span> <span class="ow">not</span> <span class="nb">hasattr</span><span class="p">(</span><span class="n">m</span><span class="p">,</span> <span class="n">sub</span><span class="p">):</span> <span class="n">subname</span> <span class="o">=</span> <span class="s2">"</span><span class="si">%s</span><span class="s2">.</span><span class="si">%s</span><span class="s2">"</span> <span class="o">%</span> <span class="p">(</span><span class="n">m</span><span class="o">.</span><span class="vm">__name__</span><span class="p">,</span> <span class="n">sub</span><span class="p">)</span> <span class="n">submod</span> <span class="o">=</span> <span class="n">import_module</span><span class="p">(</span><span class="n">sub</span><span class="p">,</span> <span class="n">subname</span><span class="p">,</span> <span class="n">m</span><span class="p">)</span> <span class="k">if</span> <span class="ow">not</span> <span class="n">submod</span><span class="p">:</span> <span class="k">raise</span> <span class="ne">ImportError</span><span class="p">(</span><span class="s2">"No module named "</span> <span class="o">+</span> <span class="n">subname</span><span class="p">)</span> <span class="k">def</span> <span class="nf">import_module</span><span class="p">(</span><span class="n">partname</span><span class="p">,</span> <span class="n">fqname</span><span class="p">,</span> <span class="n">parent</span><span class="p">):</span> <span class="k">try</span><span class="p">:</span> <span class="k">return</span> <span class="n">sys</span><span class="o">.</span><span class="n">modules</span><span class="p">[</span><span class="n">fqname</span><span class="p">]</span> <span class="k">except</span> <span class="ne">KeyError</span><span class="p">:</span> <span class="k">pass</span> <span class="k">try</span><span class="p">:</span> <span class="n">fp</span><span class="p">,</span> <span class="n">pathname</span><span class="p">,</span> <span class="n">stuff</span> <span class="o">=</span> <span class="n">imp</span><span class="o">.</span><span class="n">find_module</span><span class="p">(</span><span class="n">partname</span><span class="p">,</span> <span class="n">parent</span> <span class="ow">and</span> <span class="n">parent</span><span class="o">.</span><span class="n">__path__</span><span class="p">)</span> <span class="k">except</span> <span class="ne">ImportError</span><span class="p">:</span> <span class="k">return</span> <span class="kc">None</span> <span class="k">try</span><span class="p">:</span> <span class="n">m</span> <span class="o">=</span> <span class="n">imp</span><span class="o">.</span><span class="n">load_module</span><span class="p">(</span><span class="n">fqname</span><span class="p">,</span> <span class="n">fp</span><span class="p">,</span> <span class="n">pathname</span><span class="p">,</span> <span class="n">stuff</span><span class="p">)</span> <span class="k">finally</span><span class="p">:</span> <span class="k">if</span> <span class="n">fp</span><span class="p">:</span> <span class="n">fp</span><span class="o">.</span><span class="n">close</span><span class="p">()</span> <span class="k">if</span> <span class="n">parent</span><span class="p">:</span> <span class="nb">setattr</span><span class="p">(</span><span class="n">parent</span><span class="p">,</span> <span class="n">partname</span><span class="p">,</span> <span class="n">m</span><span class="p">)</span> <span class="k">return</span> <span class="n">m</span> <span class="c1"># Replacement for reload()</span> <span class="k">def</span> <span class="nf">reload_hook</span><span class="p">(</span><span class="n">module</span><span class="p">):</span> <span class="n">name</span> <span class="o">=</span> <span class="n">module</span><span class="o">.</span><span class="vm">__name__</span> <span class="k">if</span> <span class="s1">'.'</span> <span class="ow">not</span> <span class="ow">in</span> <span class="n">name</span><span class="p">:</span> <span class="k">return</span> <span class="n">import_module</span><span class="p">(</span><span class="n">name</span><span class="p">,</span> <span class="n">name</span><span class="p">,</span> <span class="kc">None</span><span class="p">)</span> <span class="n">i</span> <span class="o">=</span> <span class="n">name</span><span class="o">.</span><span class="n">rfind</span><span class="p">(</span><span class="s1">'.'</span><span class="p">)</span> <span class="n">pname</span> <span class="o">=</span> <span class="n">name</span><span class="p">[:</span><span class="n">i</span><span class="p">]</span> <span class="n">parent</span> <span class="o">=</span> <span class="n">sys</span><span class="o">.</span><span class="n">modules</span><span class="p">[</span><span class="n">pname</span><span class="p">]</span> <span class="k">return</span> <span class="n">import_module</span><span class="p">(</span><span class="n">name</span><span class="p">[</span><span class="n">i</span><span class="o">+</span><span class="mi">1</span><span class="p">:],</span> <span class="n">name</span><span class="p">,</span> <span class="n">parent</span><span class="p">)</span> <span class="c1"># Save the original hooks</span> <span class="n">original_import</span> <span class="o">=</span> <span class="n">__builtin__</span><span class="o">.</span><span class="n">__import__</span> <span class="n">original_reload</span> <span class="o">=</span> <span class="n">__builtin__</span><span class="o">.</span><span class="n">reload</span> <span class="c1"># Now install our hooks</span> <span class="n">__builtin__</span><span class="o">.</span><span class="n">__import__</span> <span class="o">=</span> <span class="n">import_hook</span> <span class="n">__builtin__</span><span class="o">.</span><span class="n">reload</span> <span class="o">=</span> <span class="n">reload_hook</span> </pre></div> </div> <p id="index-1">Also see the <code class="xref py py-mod docutils literal notranslate"><span class="pre">importers</span></code> module (which can be found in <code class="file docutils literal notranslate"><span class="pre">Demo/imputil/</span></code> in the Python source distribution) for additional examples.</p> </section> </section> <div class="clearer"></div> </div> </div> </div> <div class="sphinxsidebar" role="navigation" aria-label="main navigation"> <div class="sphinxsidebarwrapper"> <h3><a href="../contents.html">Table of Contents</a></h3> <ul> <li><a class="reference internal" href="#">31.3. <code class="xref py py-mod docutils literal notranslate"><span class="pre">imputil</span></code> — Import utilities</a><ul> <li><a class="reference internal" href="#examples">31.3.1. Examples</a></li> </ul> </li> </ul> <h4>Previous topic</h4> <p class="topless"><a href="importlib.html" title="previous chapter"><span class="section-number">31.2. </span><code class="xref py py-mod docutils literal notranslate"><span class="pre">importlib</span></code> — Convenience wrappers for <code class="xref py py-func docutils literal notranslate"><span class="pre">__import__()</span></code></a></p> <h4>Next topic</h4> <p class="topless"><a href="zipimport.html" title="next chapter"><span class="section-number">31.4. </span><code class="xref py py-mod docutils literal notranslate"><span class="pre">zipimport</span></code> — Import modules from Zip archives</a></p> <div role="note" aria-label="source link"> <h3>This Page</h3> <ul class="this-page-menu"> <li><a href="../_sources/library/imputil.rst.txt" rel="nofollow">Show Source</a></li> </ul> </div> <div id="searchbox" style="display: none" role="search"> <h3 id="searchlabel">Quick search</h3> <div class="searchformwrapper"> <form class="search" action="../search.html" method="get"> <input type="text" name="q" aria-labelledby="searchlabel" autocomplete="off" autocorrect="off" autocapitalize="off" spellcheck="false"/> <input type="submit" value="Go" /> </form> </div> </div> <script>$('#searchbox').show(0);</script> </div> </div> <div class="clearer"></div> </div> <div class="related" role="navigation" aria-label="related navigation"> <h3>Navigation</h3> <ul> <li class="right" style="margin-right: 10px"> <a href="../genindex.html" title="General Index" >index</a></li> <li class="right" > <a href="../py-modindex.html" title="Python Module Index" >modules</a> |</li> <li class="right" > <a href="zipimport.html" title="31.4. zipimport — Import modules from Zip archives" >next</a> |</li> <li class="right" > <a href="importlib.html" title="31.2. importlib — Convenience wrappers for __import__()" >previous</a> |</li> <li><img src="../_static/py.png" alt="" style="vertical-align: middle; margin-top: -1px"/></li> <li><a href="https://www.python.org/">Python</a> »</li> <li> <a href="../index.html">Python 2.7.18 documentation</a> » </li> <li class="nav-item nav-item-1"><a href="index.html" >The Python Standard Library</a> »</li> <li class="nav-item nav-item-2"><a href="modules.html" ><span class="section-number">31. </span>Importing Modules</a> »</li> <li class="nav-item nav-item-this"><a href=""><span class="section-number">31.3. </span><code class="xref py py-mod docutils literal notranslate"><span class="pre">imputil</span></code> — Import utilities</a></li> </ul> </div> <div class="footer"> © <a href="../copyright.html">Copyright</a> 1990-2024, Python Software Foundation. <br /> The Python Software Foundation is a non-profit corporation. <a href="https://www.python.org/psf/donations/">Please donate.</a> <br /> Last updated on November 21, 2024. <a href="../bugs.html">Found a bug</a>? <br /> Created using <a href="http://sphinx.pocoo.org/">Sphinx</a> 4.3.2. </div> </body> </html>