合规国际互联网加速 OSASE为企业客户提供高速稳定SD-WAN国际加速解决方案。 广告
### 导航 - [索引](../genindex.xhtml "总目录") - [模块](../py-modindex.xhtml "Python 模块索引") | - [下一页](readline.xhtml "readline --- GNU readline interface") | - [上一页](unicodedata.xhtml "unicodedata --- Unicode 数据库") | - ![](https://box.kancloud.cn/a721fc7ec672275e257bbbfde49a4d4e_16x16.png) - [Python](https://www.python.org/) » - zh\_CN 3.7.3 [文档](../index.xhtml) » - [Python 标准库](index.xhtml) » - [文本处理服务](text.xhtml) » - $('.inline-search').show(0); | # [`stringprep`](#module-stringprep "stringprep: String preparation, as per RFC 3453") --- Internet String Preparation **Source code:** [Lib/stringprep.py](https://github.com/python/cpython/tree/3.7/Lib/stringprep.py) \[https://github.com/python/cpython/tree/3.7/Lib/stringprep.py\] - - - - - - When identifying things (such as host names) in the internet, it is often necessary to compare such identifications for "equality". Exactly how this comparison is executed may depend on the application domain, e.g. whether it should be case-insensitive or not. It may be also necessary to restrict the possible identifications, to allow only identifications consisting of "printable" characters. [**RFC 3454**](https://tools.ietf.org/html/rfc3454.html) \[https://tools.ietf.org/html/rfc3454.html\] defines a procedure for "preparing" Unicode strings in internet protocols. Before passing strings onto the wire, they are processed with the preparation procedure, after which they have a certain normalized form. The RFC defines a set of tables, which can be combined into profiles. Each profile must define which tables it uses, and what other optional parts of the `stringprep`procedure are part of the profile. One example of a `stringprep` profile is `nameprep`, which is used for internationalized domain names. The module [`stringprep`](#module-stringprep "stringprep: String preparation, as per RFC 3453") only exposes the tables from [**RFC 3454**](https://tools.ietf.org/html/rfc3454.html) \[https://tools.ietf.org/html/rfc3454.html\]. As these tables would be very large to represent them as dictionaries or lists, the module uses the Unicode character database internally. The module source code itself was generated using the `mkstringprep.py` utility. As a result, these tables are exposed as functions, not as data structures. There are two kinds of tables in the RFC: sets and mappings. For a set, [`stringprep`](#module-stringprep "stringprep: String preparation, as per RFC 3453") provides the "characteristic function", i.e. a function that returns true if the parameter is part of the set. For mappings, it provides the mapping function: given the key, it returns the associated value. Below is a list of all functions available in the module. `stringprep.``in_table_a1`(*code*)Determine whether *code* is in tableA.1 (Unassigned code points in Unicode 3.2). `stringprep.``in_table_b1`(*code*)Determine whether *code* is in tableB.1 (Commonly mapped to nothing). `stringprep.``map_table_b2`(*code*)Return the mapped value for *code* according to tableB.2 (Mapping for case-folding used with NFKC). `stringprep.``map_table_b3`(*code*)Return the mapped value for *code* according to tableB.3 (Mapping for case-folding used with no normalization). `stringprep.``in_table_c11`(*code*)Determine whether *code* is in tableC.1.1 (ASCII space characters). `stringprep.``in_table_c12`(*code*)Determine whether *code* is in tableC.1.2 (Non-ASCII space characters). `stringprep.``in_table_c11_c12`(*code*)Determine whether *code* is in tableC.1 (Space characters, union of C.1.1 and C.1.2). `stringprep.``in_table_c21`(*code*)Determine whether *code* is in tableC.2.1 (ASCII control characters). `stringprep.``in_table_c22`(*code*)Determine whether *code* is in tableC.2.2 (Non-ASCII control characters). `stringprep.``in_table_c21_c22`(*code*)Determine whether *code* is in tableC.2 (Control characters, union of C.2.1 and C.2.2). `stringprep.``in_table_c3`(*code*)Determine whether *code* is in tableC.3 (Private use). `stringprep.``in_table_c4`(*code*)Determine whether *code* is in tableC.4 (Non-character code points). `stringprep.``in_table_c5`(*code*)Determine whether *code* is in tableC.5 (Surrogate codes). `stringprep.``in_table_c6`(*code*)Determine whether *code* is in tableC.6 (Inappropriate for plain text). `stringprep.``in_table_c7`(*code*)Determine whether *code* is in tableC.7 (Inappropriate for canonical representation). `stringprep.``in_table_c8`(*code*)Determine whether *code* is in tableC.8 (Change display properties or are deprecated). `stringprep.``in_table_c9`(*code*)Determine whether *code* is in tableC.9 (Tagging characters). `stringprep.``in_table_d1`(*code*)Determine whether *code* is in tableD.1 (Characters with bidirectional property "R" or "AL"). `stringprep.``in_table_d2`(*code*)Determine whether *code* is in tableD.2 (Characters with bidirectional property "L"). ### 导航 - [索引](../genindex.xhtml "总目录") - [模块](../py-modindex.xhtml "Python 模块索引") | - [下一页](readline.xhtml "readline --- GNU readline interface") | - [上一页](unicodedata.xhtml "unicodedata --- Unicode 数据库") | - ![](https://box.kancloud.cn/a721fc7ec672275e257bbbfde49a4d4e_16x16.png) - [Python](https://www.python.org/) » - zh\_CN 3.7.3 [文档](../index.xhtml) » - [Python 标准库](index.xhtml) » - [文本处理服务](text.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 创建。