gooderp18绿色标准版
您最多选择25个主题 主题必须以字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符

389 行
23KB

  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="mailcap — Mailcap file handling" />
  7. <meta property="og:type" content="website" />
  8. <meta property="og:url" content="https://docs.python.org/3/library/mailcap.html" />
  9. <meta property="og:site_name" content="Python documentation" />
  10. <meta property="og:description" content="Source code: Lib/mailcap.py Mailcap files are used to configure how MIME-aware applications such as mail readers and web browsers react to files with different MIME types. (The name “mailcap” is de..." />
  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/mailcap.py Mailcap files are used to configure how MIME-aware applications such as mail readers and web browsers react to files with different MIME types. (The name “mailcap” is de..." />
  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>mailcap — Mailcap file handling &#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="msilib — Read and write Microsoft Installer files" href="msilib.html" />
  33. <link rel="prev" title="imghdr — Determine the type of an image" href="imghdr.html" />
  34. <link rel="canonical" href="https://docs.python.org/3/library/mailcap.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="imghdr.html"
  85. title="previous chapter"><code class="xref py py-mod docutils literal notranslate"><span class="pre">imghdr</span></code> — Determine the type of an image</a></p>
  86. </div>
  87. <div>
  88. <h4>Next topic</h4>
  89. <p class="topless"><a href="msilib.html"
  90. title="next chapter"><code class="xref py py-mod docutils literal notranslate"><span class="pre">msilib</span></code> — Read and write Microsoft Installer files</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/mailcap.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="msilib.html" title="msilib — Read and write Microsoft Installer files"
  117. accesskey="N">next</a> |</li>
  118. <li class="right" >
  119. <a href="imghdr.html" title="imghdr — Determine the type of an image"
  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="superseded.html" accesskey="U">Superseded Modules</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">mailcap</span></code> — Mailcap file handling</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-mailcap">
  160. <span id="mailcap-mailcap-file-handling"></span><h1><a class="reference internal" href="#module-mailcap" title="mailcap: Mailcap file handling. (deprecated)"><code class="xref py py-mod docutils literal notranslate"><span class="pre">mailcap</span></code></a> — Mailcap file handling<a class="headerlink" href="#module-mailcap" 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/mailcap.py">Lib/mailcap.py</a></p>
  162. <div class="deprecated-removed">
  163. <p><span class="versionmodified">Deprecated since version 3.11, will be removed in version 3.13: </span>The <a class="reference internal" href="#module-mailcap" title="mailcap: Mailcap file handling. (deprecated)"><code class="xref py py-mod docutils literal notranslate"><span class="pre">mailcap</span></code></a> module is deprecated
  164. (see <span class="target" id="index-0"></span><a class="pep reference external" href="https://peps.python.org/pep-0594/#mailcap"><strong>PEP 594</strong></a> for details).
  165. The <a class="reference internal" href="mimetypes.html#module-mimetypes" title="mimetypes: Mapping of filename extensions to MIME types."><code class="xref py py-mod docutils literal notranslate"><span class="pre">mimetypes</span></code></a> module provides an alternative.</p>
  166. </div>
  167. <hr class="docutils" />
  168. <p>Mailcap files are used to configure how MIME-aware applications such as mail
  169. readers and web browsers react to files with different MIME types. (The name
  170. “mailcap” is derived from the phrase “mail capability”.) For example, a mailcap
  171. file might contain a line like <code class="docutils literal notranslate"><span class="pre">video/mpeg;</span> <span class="pre">xmpeg</span> <span class="pre">%s</span></code>. Then, if the user
  172. encounters an email message or web document with the MIME type
  173. <em class="mimetype">video/mpeg</em>, <code class="docutils literal notranslate"><span class="pre">%s</span></code> will be replaced by a filename (usually one
  174. belonging to a temporary file) and the <strong class="program">xmpeg</strong> program can be
  175. automatically started to view the file.</p>
  176. <p>The mailcap format is documented in <span class="target" id="index-1"></span><a class="rfc reference external" href="https://datatracker.ietf.org/doc/html/rfc1524.html"><strong>RFC 1524</strong></a>, “A User Agent Configuration
  177. Mechanism For Multimedia Mail Format Information”, but is not an internet
  178. standard. However, mailcap files are supported on most Unix systems.</p>
  179. <dl class="py function">
  180. <dt class="sig sig-object py" id="mailcap.findmatch">
  181. <span class="sig-prename descclassname"><span class="pre">mailcap.</span></span><span class="sig-name descname"><span class="pre">findmatch</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">caps</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">MIMEtype</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">key</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">'view'</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">filename</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">'/dev/null'</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">plist</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">[]</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#mailcap.findmatch" title="Link to this definition">¶</a></dt>
  182. <dd><p>Return a 2-tuple; the first element is a string containing the command line to
  183. be executed (which can be passed to <a class="reference internal" href="os.html#os.system" title="os.system"><code class="xref py py-func docutils literal notranslate"><span class="pre">os.system()</span></code></a>), and the second element
  184. is the mailcap entry for a given MIME type. If no matching MIME type can be
  185. found, <code class="docutils literal notranslate"><span class="pre">(None,</span> <span class="pre">None)</span></code> is returned.</p>
  186. <p><em>key</em> is the name of the field desired, which represents the type of activity to
  187. be performed; the default value is ‘view’, since in the most common case you
  188. simply want to view the body of the MIME-typed data. Other possible values
  189. might be ‘compose’ and ‘edit’, if you wanted to create a new body of the given
  190. MIME type or alter the existing body data. See <span class="target" id="index-2"></span><a class="rfc reference external" href="https://datatracker.ietf.org/doc/html/rfc1524.html"><strong>RFC 1524</strong></a> for a complete list
  191. of these fields.</p>
  192. <p><em>filename</em> is the filename to be substituted for <code class="docutils literal notranslate"><span class="pre">%s</span></code> in the command line; the
  193. default value is <code class="docutils literal notranslate"><span class="pre">'/dev/null'</span></code> which is almost certainly not what you want, so
  194. usually you’ll override it by specifying a filename.</p>
  195. <p><em>plist</em> can be a list containing named parameters; the default value is simply
  196. an empty list. Each entry in the list must be a string containing the parameter
  197. name, an equals sign (<code class="docutils literal notranslate"><span class="pre">'='</span></code>), and the parameter’s value. Mailcap entries can
  198. contain named parameters like <code class="docutils literal notranslate"><span class="pre">%{foo}</span></code>, which will be replaced by the value
  199. of the parameter named ‘foo’. For example, if the command line <code class="docutils literal notranslate"><span class="pre">showpartial</span>
  200. <span class="pre">%{id}</span> <span class="pre">%{number}</span> <span class="pre">%{total}</span></code> was in a mailcap file, and <em>plist</em> was set to
  201. <code class="docutils literal notranslate"><span class="pre">['id=1',</span> <span class="pre">'number=2',</span> <span class="pre">'total=3']</span></code>, the resulting command line would be
  202. <code class="docutils literal notranslate"><span class="pre">'showpartial</span> <span class="pre">1</span> <span class="pre">2</span> <span class="pre">3'</span></code>.</p>
  203. <p>In a mailcap file, the “test” field can optionally be specified to test some
  204. external condition (such as the machine architecture, or the window system in
  205. use) to determine whether or not the mailcap line applies. <a class="reference internal" href="#mailcap.findmatch" title="mailcap.findmatch"><code class="xref py py-func docutils literal notranslate"><span class="pre">findmatch()</span></code></a>
  206. will automatically check such conditions and skip the entry if the check fails.</p>
  207. <div class="versionchanged">
  208. <p><span class="versionmodified changed">Changed in version 3.11: </span>To prevent security issues with shell metacharacters (symbols that have
  209. special effects in a shell command line), <code class="docutils literal notranslate"><span class="pre">findmatch</span></code> will refuse
  210. to inject ASCII characters other than alphanumerics and <code class="docutils literal notranslate"><span class="pre">&#64;+=:,./-_</span></code>
  211. into the returned command line.</p>
  212. <p>If a disallowed character appears in <em>filename</em>, <code class="docutils literal notranslate"><span class="pre">findmatch</span></code> will always
  213. return <code class="docutils literal notranslate"><span class="pre">(None,</span> <span class="pre">None)</span></code> as if no entry was found.
  214. If such a character appears elsewhere (a value in <em>plist</em> or in <em>MIMEtype</em>),
  215. <code class="docutils literal notranslate"><span class="pre">findmatch</span></code> will ignore all mailcap entries which use that value.
  216. A <a class="reference internal" href="warnings.html#module-warnings" title="warnings: Issue warning messages and control their disposition."><code class="xref py py-mod docutils literal notranslate"><span class="pre">warning</span></code></a> will be raised in either case.</p>
  217. </div>
  218. </dd></dl>
  219. <dl class="py function">
  220. <dt class="sig sig-object py" id="mailcap.getcaps">
  221. <span class="sig-prename descclassname"><span class="pre">mailcap.</span></span><span class="sig-name descname"><span class="pre">getcaps</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="headerlink" href="#mailcap.getcaps" title="Link to this definition">¶</a></dt>
  222. <dd><p>Returns a dictionary mapping MIME types to a list of mailcap file entries. This
  223. dictionary must be passed to the <a class="reference internal" href="#mailcap.findmatch" title="mailcap.findmatch"><code class="xref py py-func docutils literal notranslate"><span class="pre">findmatch()</span></code></a> function. An entry is stored
  224. as a list of dictionaries, but it shouldn’t be necessary to know the details of
  225. this representation.</p>
  226. <p>The information is derived from all of the mailcap files found on the system.
  227. Settings in the user’s mailcap file <code class="file docutils literal notranslate"><span class="pre">$HOME/.mailcap</span></code> will override
  228. settings in the system mailcap files <code class="file docutils literal notranslate"><span class="pre">/etc/mailcap</span></code>,
  229. <code class="file docutils literal notranslate"><span class="pre">/usr/etc/mailcap</span></code>, and <code class="file docutils literal notranslate"><span class="pre">/usr/local/etc/mailcap</span></code>.</p>
  230. </dd></dl>
  231. <p>An example usage:</p>
  232. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="kn">import</span> <span class="nn">mailcap</span>
  233. <span class="gp">&gt;&gt;&gt; </span><span class="n">d</span> <span class="o">=</span> <span class="n">mailcap</span><span class="o">.</span><span class="n">getcaps</span><span class="p">()</span>
  234. <span class="gp">&gt;&gt;&gt; </span><span class="n">mailcap</span><span class="o">.</span><span class="n">findmatch</span><span class="p">(</span><span class="n">d</span><span class="p">,</span> <span class="s1">&#39;video/mpeg&#39;</span><span class="p">,</span> <span class="n">filename</span><span class="o">=</span><span class="s1">&#39;tmp1223&#39;</span><span class="p">)</span>
  235. <span class="go">(&#39;xmpeg tmp1223&#39;, {&#39;view&#39;: &#39;xmpeg %s&#39;})</span>
  236. </pre></div>
  237. </div>
  238. </section>
  239. <div class="clearer"></div>
  240. </div>
  241. </div>
  242. </div>
  243. <div class="sphinxsidebar" role="navigation" aria-label="main navigation">
  244. <div class="sphinxsidebarwrapper">
  245. <div>
  246. <h4>Previous topic</h4>
  247. <p class="topless"><a href="imghdr.html"
  248. title="previous chapter"><code class="xref py py-mod docutils literal notranslate"><span class="pre">imghdr</span></code> — Determine the type of an image</a></p>
  249. </div>
  250. <div>
  251. <h4>Next topic</h4>
  252. <p class="topless"><a href="msilib.html"
  253. title="next chapter"><code class="xref py py-mod docutils literal notranslate"><span class="pre">msilib</span></code> — Read and write Microsoft Installer files</a></p>
  254. </div>
  255. <div role="note" aria-label="source link">
  256. <h3>This Page</h3>
  257. <ul class="this-page-menu">
  258. <li><a href="../bugs.html">Report a Bug</a></li>
  259. <li>
  260. <a href="https://github.com/python/cpython/blob/main/Doc/library/mailcap.rst"
  261. rel="nofollow">Show Source
  262. </a>
  263. </li>
  264. </ul>
  265. </div>
  266. </div>
  267. <div id="sidebarbutton" title="Collapse sidebar">
  268. <span>«</span>
  269. </div>
  270. </div>
  271. <div class="clearer"></div>
  272. </div>
  273. <div class="related" role="navigation" aria-label="related navigation">
  274. <h3>Navigation</h3>
  275. <ul>
  276. <li class="right" style="margin-right: 10px">
  277. <a href="../genindex.html" title="General Index"
  278. >index</a></li>
  279. <li class="right" >
  280. <a href="../py-modindex.html" title="Python Module Index"
  281. >modules</a> |</li>
  282. <li class="right" >
  283. <a href="msilib.html" title="msilib — Read and write Microsoft Installer files"
  284. >next</a> |</li>
  285. <li class="right" >
  286. <a href="imghdr.html" title="imghdr — Determine the type of an image"
  287. >previous</a> |</li>
  288. <li><img src="../_static/py.svg" alt="Python logo" style="vertical-align: middle; margin-top: -1px"/></li>
  289. <li><a href="https://www.python.org/">Python</a> &#187;</li>
  290. <li class="switchers">
  291. <div class="language_switcher_placeholder"></div>
  292. <div class="version_switcher_placeholder"></div>
  293. </li>
  294. <li>
  295. </li>
  296. <li id="cpython-language-and-version">
  297. <a href="../index.html">3.12.3 Documentation</a> &#187;
  298. </li>
  299. <li class="nav-item nav-item-1"><a href="index.html" >The Python Standard Library</a> &#187;</li>
  300. <li class="nav-item nav-item-2"><a href="superseded.html" >Superseded Modules</a> &#187;</li>
  301. <li class="nav-item nav-item-this"><a href=""><code class="xref py py-mod docutils literal notranslate"><span class="pre">mailcap</span></code> — Mailcap file handling</a></li>
  302. <li class="right">
  303. <div class="inline-search" role="search">
  304. <form class="inline-search" action="../search.html" method="get">
  305. <input placeholder="Quick search" aria-label="Quick search" type="search" name="q" id="search-box" />
  306. <input type="submit" value="Go" />
  307. </form>
  308. </div>
  309. |
  310. </li>
  311. <li class="right">
  312. <label class="theme-selector-label">
  313. Theme
  314. <select class="theme-selector" oninput="activateTheme(this.value)">
  315. <option value="auto" selected>Auto</option>
  316. <option value="light">Light</option>
  317. <option value="dark">Dark</option>
  318. </select>
  319. </label> |</li>
  320. </ul>
  321. </div>
  322. <div class="footer">
  323. &copy;
  324. <a href="../copyright.html">
  325. Copyright
  326. </a>
  327. 2001-2024, Python Software Foundation.
  328. <br />
  329. This page is licensed under the Python Software Foundation License Version 2.
  330. <br />
  331. Examples, recipes, and other code in the documentation are additionally licensed under the Zero Clause BSD License.
  332. <br />
  333. See <a href="/license.html">History and License</a> for more information.<br />
  334. <br />
  335. The Python Software Foundation is a non-profit corporation.
  336. <a href="https://www.python.org/psf/donations/">Please donate.</a>
  337. <br />
  338. <br />
  339. Last updated on Apr 09, 2024 (13:47 UTC).
  340. <a href="/bugs.html">Found a bug</a>?
  341. <br />
  342. Created using <a href="https://www.sphinx-doc.org/">Sphinx</a> 7.2.6.
  343. </div>
  344. </body>
  345. </html>
上海开阖软件有限公司 沪ICP备12045867号-1