gooderp18绿色标准版
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

393 line
21KB

  1. <!DOCTYPE html>
  2. <html lang="en" data-content_root="../">
  3. <head>
  4. <meta charset="utf-8" />
  5. <meta name="viewport" content="width=device-width, initial-scale=1.0" /><meta name="viewport" content="width=device-width, initial-scale=1" />
  6. <meta property="og:title" content="pydoc — Documentation generator and online help system" />
  7. <meta property="og:type" content="website" />
  8. <meta property="og:url" content="https://docs.python.org/3/library/pydoc.html" />
  9. <meta property="og:site_name" content="Python documentation" />
  10. <meta property="og:description" content="Source code: Lib/pydoc.py The pydoc module automatically generates documentation from Python modules. The documentation can be presented as pages of text on the console, served to a web browser, or..." />
  11. <meta property="og:image" content="https://docs.python.org/3/_static/og-image.png" />
  12. <meta property="og:image:alt" content="Python documentation" />
  13. <meta name="description" content="Source code: Lib/pydoc.py The pydoc module automatically generates documentation from Python modules. The documentation can be presented as pages of text on the console, served to a web browser, or..." />
  14. <meta property="og:image:width" content="200" />
  15. <meta property="og:image:height" content="200" />
  16. <meta name="theme-color" content="#3776ab" />
  17. <title>pydoc — Documentation generator and online help system &#8212; Python 3.12.3 documentation</title><meta name="viewport" content="width=device-width, initial-scale=1.0">
  18. <link rel="stylesheet" type="text/css" href="../_static/pygments.css?v=80d5e7a1" />
  19. <link rel="stylesheet" type="text/css" href="../_static/pydoctheme.css?v=bb723527" />
  20. <link id="pygments_dark_css" media="(prefers-color-scheme: dark)" rel="stylesheet" type="text/css" href="../_static/pygments_dark.css?v=b20cc3f5" />
  21. <script src="../_static/documentation_options.js?v=2c828074"></script>
  22. <script src="../_static/doctools.js?v=888ff710"></script>
  23. <script src="../_static/sphinx_highlight.js?v=dc90522c"></script>
  24. <script src="../_static/sidebar.js"></script>
  25. <link rel="search" type="application/opensearchdescription+xml"
  26. title="Search within Python 3.12.3 documentation"
  27. href="../_static/opensearch.xml"/>
  28. <link rel="author" title="About these documents" href="../about.html" />
  29. <link rel="index" title="Index" href="../genindex.html" />
  30. <link rel="search" title="Search" href="../search.html" />
  31. <link rel="copyright" title="Copyright" href="../copyright.html" />
  32. <link rel="next" title="Python Development Mode" href="devmode.html" />
  33. <link rel="prev" title="typing — Support for type hints" href="typing.html" />
  34. <link rel="canonical" href="https://docs.python.org/3/library/pydoc.html" />
  35. <style>
  36. @media only screen {
  37. table.full-width-table {
  38. width: 100%;
  39. }
  40. }
  41. </style>
  42. <link rel="stylesheet" href="../_static/pydoctheme_dark.css" media="(prefers-color-scheme: dark)" id="pydoctheme_dark_css">
  43. <link rel="shortcut icon" type="image/png" href="../_static/py.svg" />
  44. <script type="text/javascript" src="../_static/copybutton.js"></script>
  45. <script type="text/javascript" src="../_static/menu.js"></script>
  46. <script type="text/javascript" src="../_static/search-focus.js"></script>
  47. <script type="text/javascript" src="../_static/themetoggle.js"></script>
  48. </head>
  49. <body>
  50. <div class="mobile-nav">
  51. <input type="checkbox" id="menuToggler" class="toggler__input" aria-controls="navigation"
  52. aria-pressed="false" aria-expanded="false" role="button" aria-label="Menu" />
  53. <nav class="nav-content" role="navigation">
  54. <label for="menuToggler" class="toggler__label">
  55. <span></span>
  56. </label>
  57. <span class="nav-items-wrapper">
  58. <a href="https://www.python.org/" class="nav-logo">
  59. <img src="../_static/py.svg" alt="Python logo"/>
  60. </a>
  61. <span class="version_switcher_placeholder"></span>
  62. <form role="search" class="search" action="../search.html" method="get">
  63. <svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" class="search-icon">
  64. <path fill-rule="nonzero" fill="currentColor" d="M15.5 14h-.79l-.28-.27a6.5 6.5 0 001.48-5.34c-.47-2.78-2.79-5-5.59-5.34a6.505 6.505 0 00-7.27 7.27c.34 2.8 2.56 5.12 5.34 5.59a6.5 6.5 0 005.34-1.48l.27.28v.79l4.25 4.25c.41.41 1.08.41 1.49 0 .41-.41.41-1.08 0-1.49L15.5 14zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14z"></path>
  65. </svg>
  66. <input placeholder="Quick search" aria-label="Quick search" type="search" name="q" />
  67. <input type="submit" value="Go"/>
  68. </form>
  69. </span>
  70. </nav>
  71. <div class="menu-wrapper">
  72. <nav class="menu" role="navigation" aria-label="main navigation">
  73. <div class="language_switcher_placeholder"></div>
  74. <label class="theme-selector-label">
  75. Theme
  76. <select class="theme-selector" oninput="activateTheme(this.value)">
  77. <option value="auto" selected>Auto</option>
  78. <option value="light">Light</option>
  79. <option value="dark">Dark</option>
  80. </select>
  81. </label>
  82. <div>
  83. <h4>Previous topic</h4>
  84. <p class="topless"><a href="typing.html"
  85. title="previous chapter"><code class="xref py py-mod docutils literal notranslate"><span class="pre">typing</span></code> — Support for type hints</a></p>
  86. </div>
  87. <div>
  88. <h4>Next topic</h4>
  89. <p class="topless"><a href="devmode.html"
  90. title="next chapter">Python Development Mode</a></p>
  91. </div>
  92. <div role="note" aria-label="source link">
  93. <h3>This Page</h3>
  94. <ul class="this-page-menu">
  95. <li><a href="../bugs.html">Report a Bug</a></li>
  96. <li>
  97. <a href="https://github.com/python/cpython/blob/main/Doc/library/pydoc.rst"
  98. rel="nofollow">Show Source
  99. </a>
  100. </li>
  101. </ul>
  102. </div>
  103. </nav>
  104. </div>
  105. </div>
  106. <div class="related" role="navigation" aria-label="related navigation">
  107. <h3>Navigation</h3>
  108. <ul>
  109. <li class="right" style="margin-right: 10px">
  110. <a href="../genindex.html" title="General Index"
  111. accesskey="I">index</a></li>
  112. <li class="right" >
  113. <a href="../py-modindex.html" title="Python Module Index"
  114. >modules</a> |</li>
  115. <li class="right" >
  116. <a href="devmode.html" title="Python Development Mode"
  117. accesskey="N">next</a> |</li>
  118. <li class="right" >
  119. <a href="typing.html" title="typing — Support for type hints"
  120. accesskey="P">previous</a> |</li>
  121. <li><img src="../_static/py.svg" alt="Python logo" style="vertical-align: middle; margin-top: -1px"/></li>
  122. <li><a href="https://www.python.org/">Python</a> &#187;</li>
  123. <li class="switchers">
  124. <div class="language_switcher_placeholder"></div>
  125. <div class="version_switcher_placeholder"></div>
  126. </li>
  127. <li>
  128. </li>
  129. <li id="cpython-language-and-version">
  130. <a href="../index.html">3.12.3 Documentation</a> &#187;
  131. </li>
  132. <li class="nav-item nav-item-1"><a href="index.html" >The Python Standard Library</a> &#187;</li>
  133. <li class="nav-item nav-item-2"><a href="development.html" accesskey="U">Development Tools</a> &#187;</li>
  134. <li class="nav-item nav-item-this"><a href=""><code class="xref py py-mod docutils literal notranslate"><span class="pre">pydoc</span></code> — Documentation generator and online help system</a></li>
  135. <li class="right">
  136. <div class="inline-search" role="search">
  137. <form class="inline-search" action="../search.html" method="get">
  138. <input placeholder="Quick search" aria-label="Quick search" type="search" name="q" id="search-box" />
  139. <input type="submit" value="Go" />
  140. </form>
  141. </div>
  142. |
  143. </li>
  144. <li class="right">
  145. <label class="theme-selector-label">
  146. Theme
  147. <select class="theme-selector" oninput="activateTheme(this.value)">
  148. <option value="auto" selected>Auto</option>
  149. <option value="light">Light</option>
  150. <option value="dark">Dark</option>
  151. </select>
  152. </label> |</li>
  153. </ul>
  154. </div>
  155. <div class="document">
  156. <div class="documentwrapper">
  157. <div class="bodywrapper">
  158. <div class="body" role="main">
  159. <section id="module-pydoc">
  160. <span id="pydoc-documentation-generator-and-online-help-system"></span><h1><a class="reference internal" href="#module-pydoc" title="pydoc: Documentation generator and online help system."><code class="xref py py-mod docutils literal notranslate"><span class="pre">pydoc</span></code></a> — Documentation generator and online help system<a class="headerlink" href="#module-pydoc" title="Link to this heading">¶</a></h1>
  161. <p><strong>Source code:</strong> <a class="reference external" href="https://github.com/python/cpython/tree/3.12/Lib/pydoc.py">Lib/pydoc.py</a></p>
  162. <hr class="docutils" id="index-0" />
  163. <p>The <code class="xref py py-mod docutils literal notranslate"><span class="pre">pydoc</span></code> module automatically generates documentation from Python
  164. modules. The documentation can be presented as pages of text on the console,
  165. served to a web browser, or saved to HTML files.</p>
  166. <p>For modules, classes, functions and methods, the displayed documentation is
  167. derived from the docstring (i.e. the <code class="xref py py-attr docutils literal notranslate"><span class="pre">__doc__</span></code> attribute) of the object,
  168. and recursively of its documentable members. If there is no docstring,
  169. <code class="xref py py-mod docutils literal notranslate"><span class="pre">pydoc</span></code> tries to obtain a description from the block of comment lines just
  170. above the definition of the class, function or method in the source file, or at
  171. the top of the module (see <a class="reference internal" href="inspect.html#inspect.getcomments" title="inspect.getcomments"><code class="xref py py-func docutils literal notranslate"><span class="pre">inspect.getcomments()</span></code></a>).</p>
  172. <p>The built-in function <a class="reference internal" href="functions.html#help" title="help"><code class="xref py py-func docutils literal notranslate"><span class="pre">help()</span></code></a> invokes the online help system in the
  173. interactive interpreter, which uses <code class="xref py py-mod docutils literal notranslate"><span class="pre">pydoc</span></code> to generate its documentation
  174. as text on the console. The same text documentation can also be viewed from
  175. outside the Python interpreter by running <strong class="program">pydoc</strong> as a script at the
  176. operating system’s command prompt. For example, running</p>
  177. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="n">python</span> <span class="o">-</span><span class="n">m</span> <span class="n">pydoc</span> <span class="n">sys</span>
  178. </pre></div>
  179. </div>
  180. <p>at a shell prompt will display documentation on the <a class="reference internal" href="sys.html#module-sys" title="sys: Access system-specific parameters and functions."><code class="xref py py-mod docutils literal notranslate"><span class="pre">sys</span></code></a> module, in a
  181. style similar to the manual pages shown by the Unix <strong class="program">man</strong> command. The
  182. argument to <strong class="program">pydoc</strong> can be the name of a function, module, or package,
  183. or a dotted reference to a class, method, or function within a module or module
  184. in a package. If the argument to <strong class="program">pydoc</strong> looks like a path (that is,
  185. it contains the path separator for your operating system, such as a slash in
  186. Unix), and refers to an existing Python source file, then documentation is
  187. produced for that file.</p>
  188. <div class="admonition note">
  189. <p class="admonition-title">Note</p>
  190. <p>In order to find objects and their documentation, <code class="xref py py-mod docutils literal notranslate"><span class="pre">pydoc</span></code> imports the
  191. module(s) to be documented. Therefore, any code on module level will be
  192. executed on that occasion. Use an <code class="docutils literal notranslate"><span class="pre">if</span> <span class="pre">__name__</span> <span class="pre">==</span> <span class="pre">'__main__':</span></code> guard to
  193. only execute code when a file is invoked as a script and not just imported.</p>
  194. </div>
  195. <p>When printing output to the console, <strong class="program">pydoc</strong> attempts to paginate the
  196. output for easier reading. If the <span class="target" id="index-1"></span><code class="xref std std-envvar docutils literal notranslate"><span class="pre">PAGER</span></code> environment variable is set,
  197. <strong class="program">pydoc</strong> will use its value as a pagination program.</p>
  198. <p>Specifying a <code class="docutils literal notranslate"><span class="pre">-w</span></code> flag before the argument will cause HTML documentation
  199. to be written out to a file in the current directory, instead of displaying text
  200. on the console.</p>
  201. <p>Specifying a <code class="docutils literal notranslate"><span class="pre">-k</span></code> flag before the argument will search the synopsis
  202. lines of all available modules for the keyword given as the argument, again in a
  203. manner similar to the Unix <strong class="program">man</strong> command. The synopsis line of a
  204. module is the first line of its documentation string.</p>
  205. <p>You can also use <strong class="program">pydoc</strong> to start an HTTP server on the local machine
  206. that will serve documentation to visiting web browsers. <strong class="program">python -m pydoc -p 1234</strong>
  207. will start a HTTP server on port 1234, allowing you to browse the
  208. documentation at <code class="docutils literal notranslate"><span class="pre">http://localhost:1234/</span></code> in your preferred web browser.
  209. Specifying <code class="docutils literal notranslate"><span class="pre">0</span></code> as the port number will select an arbitrary unused port.</p>
  210. <p><strong class="program">python -m pydoc -n &lt;hostname&gt;</strong> will start the server listening at the given
  211. hostname. By default the hostname is ‘localhost’ but if you want the server to
  212. be reached from other machines, you may want to change the host name that the
  213. server responds to. During development this is especially useful if you want
  214. to run pydoc from within a container.</p>
  215. <p><strong class="program">python -m pydoc -b</strong> will start the server and additionally open a web
  216. browser to a module index page. Each served page has a navigation bar at the
  217. top where you can <em>Get</em> help on an individual item, <em>Search</em> all modules with a
  218. keyword in their synopsis line, and go to the <em>Module index</em>, <em>Topics</em> and
  219. <em>Keywords</em> pages.</p>
  220. <p>When <strong class="program">pydoc</strong> generates documentation, it uses the current environment
  221. and path to locate modules. Thus, invoking <strong class="program">pydoc spam</strong>
  222. documents precisely the version of the module you would get if you started the
  223. Python interpreter and typed <code class="docutils literal notranslate"><span class="pre">import</span> <span class="pre">spam</span></code>.</p>
  224. <p>Module docs for core modules are assumed to reside in
  225. <code class="docutils literal notranslate"><span class="pre">https://docs.python.org/X.Y/library/</span></code> where <code class="docutils literal notranslate"><span class="pre">X</span></code> and <code class="docutils literal notranslate"><span class="pre">Y</span></code> are the
  226. major and minor version numbers of the Python interpreter. This can
  227. be overridden by setting the <code class="xref std std-envvar docutils literal notranslate"><span class="pre">PYTHONDOCS</span></code> environment variable
  228. to a different URL or to a local directory containing the Library
  229. Reference Manual pages.</p>
  230. <div class="versionchanged">
  231. <p><span class="versionmodified changed">Changed in version 3.2: </span>Added the <code class="docutils literal notranslate"><span class="pre">-b</span></code> option.</p>
  232. </div>
  233. <div class="versionchanged">
  234. <p><span class="versionmodified changed">Changed in version 3.3: </span>The <code class="docutils literal notranslate"><span class="pre">-g</span></code> command line option was removed.</p>
  235. </div>
  236. <div class="versionchanged">
  237. <p><span class="versionmodified changed">Changed in version 3.4: </span><code class="xref py py-mod docutils literal notranslate"><span class="pre">pydoc</span></code> now uses <a class="reference internal" href="inspect.html#inspect.signature" title="inspect.signature"><code class="xref py py-func docutils literal notranslate"><span class="pre">inspect.signature()</span></code></a> rather than
  238. <a class="reference internal" href="inspect.html#inspect.getfullargspec" title="inspect.getfullargspec"><code class="xref py py-func docutils literal notranslate"><span class="pre">inspect.getfullargspec()</span></code></a> to extract signature information from
  239. callables.</p>
  240. </div>
  241. <div class="versionchanged">
  242. <p><span class="versionmodified changed">Changed in version 3.7: </span>Added the <code class="docutils literal notranslate"><span class="pre">-n</span></code> option.</p>
  243. </div>
  244. </section>
  245. <div class="clearer"></div>
  246. </div>
  247. </div>
  248. </div>
  249. <div class="sphinxsidebar" role="navigation" aria-label="main navigation">
  250. <div class="sphinxsidebarwrapper">
  251. <div>
  252. <h4>Previous topic</h4>
  253. <p class="topless"><a href="typing.html"
  254. title="previous chapter"><code class="xref py py-mod docutils literal notranslate"><span class="pre">typing</span></code> — Support for type hints</a></p>
  255. </div>
  256. <div>
  257. <h4>Next topic</h4>
  258. <p class="topless"><a href="devmode.html"
  259. title="next chapter">Python Development Mode</a></p>
  260. </div>
  261. <div role="note" aria-label="source link">
  262. <h3>This Page</h3>
  263. <ul class="this-page-menu">
  264. <li><a href="../bugs.html">Report a Bug</a></li>
  265. <li>
  266. <a href="https://github.com/python/cpython/blob/main/Doc/library/pydoc.rst"
  267. rel="nofollow">Show Source
  268. </a>
  269. </li>
  270. </ul>
  271. </div>
  272. </div>
  273. <div id="sidebarbutton" title="Collapse sidebar">
  274. <span>«</span>
  275. </div>
  276. </div>
  277. <div class="clearer"></div>
  278. </div>
  279. <div class="related" role="navigation" aria-label="related navigation">
  280. <h3>Navigation</h3>
  281. <ul>
  282. <li class="right" style="margin-right: 10px">
  283. <a href="../genindex.html" title="General Index"
  284. >index</a></li>
  285. <li class="right" >
  286. <a href="../py-modindex.html" title="Python Module Index"
  287. >modules</a> |</li>
  288. <li class="right" >
  289. <a href="devmode.html" title="Python Development Mode"
  290. >next</a> |</li>
  291. <li class="right" >
  292. <a href="typing.html" title="typing — Support for type hints"
  293. >previous</a> |</li>
  294. <li><img src="../_static/py.svg" alt="Python logo" style="vertical-align: middle; margin-top: -1px"/></li>
  295. <li><a href="https://www.python.org/">Python</a> &#187;</li>
  296. <li class="switchers">
  297. <div class="language_switcher_placeholder"></div>
  298. <div class="version_switcher_placeholder"></div>
  299. </li>
  300. <li>
  301. </li>
  302. <li id="cpython-language-and-version">
  303. <a href="../index.html">3.12.3 Documentation</a> &#187;
  304. </li>
  305. <li class="nav-item nav-item-1"><a href="index.html" >The Python Standard Library</a> &#187;</li>
  306. <li class="nav-item nav-item-2"><a href="development.html" >Development Tools</a> &#187;</li>
  307. <li class="nav-item nav-item-this"><a href=""><code class="xref py py-mod docutils literal notranslate"><span class="pre">pydoc</span></code> — Documentation generator and online help system</a></li>
  308. <li class="right">
  309. <div class="inline-search" role="search">
  310. <form class="inline-search" action="../search.html" method="get">
  311. <input placeholder="Quick search" aria-label="Quick search" type="search" name="q" id="search-box" />
  312. <input type="submit" value="Go" />
  313. </form>
  314. </div>
  315. |
  316. </li>
  317. <li class="right">
  318. <label class="theme-selector-label">
  319. Theme
  320. <select class="theme-selector" oninput="activateTheme(this.value)">
  321. <option value="auto" selected>Auto</option>
  322. <option value="light">Light</option>
  323. <option value="dark">Dark</option>
  324. </select>
  325. </label> |</li>
  326. </ul>
  327. </div>
  328. <div class="footer">
  329. &copy;
  330. <a href="../copyright.html">
  331. Copyright
  332. </a>
  333. 2001-2024, Python Software Foundation.
  334. <br />
  335. This page is licensed under the Python Software Foundation License Version 2.
  336. <br />
  337. Examples, recipes, and other code in the documentation are additionally licensed under the Zero Clause BSD License.
  338. <br />
  339. See <a href="/license.html">History and License</a> for more information.<br />
  340. <br />
  341. The Python Software Foundation is a non-profit corporation.
  342. <a href="https://www.python.org/psf/donations/">Please donate.</a>
  343. <br />
  344. <br />
  345. Last updated on Apr 09, 2024 (13:47 UTC).
  346. <a href="/bugs.html">Found a bug</a>?
  347. <br />
  348. Created using <a href="https://www.sphinx-doc.org/">Sphinx</a> 7.2.6.
  349. </div>
  350. </body>
  351. </html>
上海开阖软件有限公司 沪ICP备12045867号-1