ThinkChat2.0新版上线,更智能更精彩,支持会话、画图、阅读、搜索等,送10W Token,即刻开启你的AI之旅 广告
### 导航 - [索引](../genindex.xhtml "总目录") - [模块](../py-modindex.xhtml "Python 模块索引") | - [下一页](mailbox.xhtml "mailbox --- Manipulate mailboxes in various formats") | - [上一页](json.xhtml "json --- JSON 编码和解码器") | - ![](https://box.kancloud.cn/a721fc7ec672275e257bbbfde49a4d4e_16x16.png) - [Python](https://www.python.org/) » - zh\_CN 3.7.3 [文档](../index.xhtml) » - [Python 标准库](index.xhtml) » - [互联网数据处理](netdata.xhtml) » - $('.inline-search').show(0); | # [`mailcap`](#module-mailcap "mailcap: Mailcap file handling.") --- Mailcap file handling **Source code:** [Lib/mailcap.py](https://github.com/python/cpython/tree/3.7/Lib/mailcap.py) \[https://github.com/python/cpython/tree/3.7/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 derived from the phrase "mail capability".) For example, a mailcap file might contain a line like `video/mpeg; xmpeg %s`. Then, if the user encounters an email message or Web document with the MIME type *video/mpeg*, `%s` will be replaced by a filename (usually one belonging to a temporary file) and the **xmpeg** program can be automatically started to view the file. The mailcap format is documented in [**RFC 1524**](https://tools.ietf.org/html/rfc1524.html) \[https://tools.ietf.org/html/rfc1524.html\], "A User Agent Configuration Mechanism For Multimedia Mail Format Information," but is not an Internet standard. However, mailcap files are supported on most Unix systems. `mailcap.``findmatch`(*caps*, *MIMEtype*, *key='view'*, *filename='/dev/null'*, *plist=\[\]*)Return a 2-tuple; the first element is a string containing the command line to be executed (which can be passed to [`os.system()`](os.xhtml#os.system "os.system")), and the second element is the mailcap entry for a given MIME type. If no matching MIME type can be found, `(None, None)` is returned. *key* is the name of the field desired, which represents the type of activity to be performed; the default value is 'view', since in the most common case you simply want to view the body of the MIME-typed data. Other possible values might be 'compose' and 'edit', if you wanted to create a new body of the given MIME type or alter the existing body data. See [**RFC 1524**](https://tools.ietf.org/html/rfc1524.html) \[https://tools.ietf.org/html/rfc1524.html\] for a complete list of these fields. *filename* is the filename to be substituted for `%s` in the command line; the default value is `'/dev/null'` which is almost certainly not what you want, so usually you'll override it by specifying a filename. *plist* can be a list containing named parameters; the default value is simply an empty list. Each entry in the list must be a string containing the parameter name, an equals sign (`'='`), and the parameter's value. Mailcap entries can contain named parameters like `%{foo}`, which will be replaced by the value of the parameter named 'foo'. For example, if the command line ``` showpartial %{id} %{number} %{total} ``` was in a mailcap file, and *plist* was set to `['id=1', 'number=2', 'total=3']`, the resulting command line would be `'showpartial 1 2 3'`. In a mailcap file, the "test" field can optionally be specified to test some external condition (such as the machine architecture, or the window system in use) to determine whether or not the mailcap line applies. [`findmatch()`](#mailcap.findmatch "mailcap.findmatch")will automatically check such conditions and skip the entry if the check fails. `mailcap.``getcaps`()Returns a dictionary mapping MIME types to a list of mailcap file entries. This dictionary must be passed to the [`findmatch()`](#mailcap.findmatch "mailcap.findmatch") function. An entry is stored as a list of dictionaries, but it shouldn't be necessary to know the details of this representation. The information is derived from all of the mailcap files found on the system. Settings in the user's mailcap file `$HOME/.mailcap` will override settings in the system mailcap files `/etc/mailcap`, `/usr/etc/mailcap`, and `/usr/local/etc/mailcap`. An example usage: ``` >>> import mailcap >>> d = mailcap.getcaps() >>> mailcap.findmatch(d, 'video/mpeg', filename='tmp1223') ('xmpeg tmp1223', {'view': 'xmpeg %s'}) ``` ### 导航 - [索引](../genindex.xhtml "总目录") - [模块](../py-modindex.xhtml "Python 模块索引") | - [下一页](mailbox.xhtml "mailbox --- Manipulate mailboxes in various formats") | - [上一页](json.xhtml "json --- JSON 编码和解码器") | - ![](https://box.kancloud.cn/a721fc7ec672275e257bbbfde49a4d4e_16x16.png) - [Python](https://www.python.org/) » - zh\_CN 3.7.3 [文档](../index.xhtml) » - [Python 标准库](index.xhtml) » - [互联网数据处理](netdata.xhtml) » - $('.inline-search').show(0); | © [版权所有](../copyright.xhtml) 2001-2019, Python Software Foundation. Python 软件基金会是一个非盈利组织。 [请捐助。](https://www.python.org/psf/donations/) 最后更新于 5月 21, 2019. [发现了问题](../bugs.xhtml)? 使用[Sphinx](http://sphinx.pocoo.org/)1.8.4 创建。