从 Python 中的字符串中剥离不可打印的字符
与 Perl 相比,Python 缺少 POSIX 正则表达式类,因此很难检测并使用正则表达式删除不可打印的字符。
那么,如何在 Python 中实现此目的?
一种方法是利用 unicodedata 模块。 unicodedata.category 函数将 Unicode 字符分为各种类别。例如,分类为 Cc(控制)的字符代表不可打印的字符。
利用这些知识,您可以构造一个匹配所有控制字符的自定义字符类:
<code class="python">import unicodedata import re import sys all_chars = (chr(i) for i in range(sys.maxunicode)) categories = {'Cc'} control_chars = ''.join(c for c in all_chars if unicodedata.category(c) in categories) control_char_re = re.compile('[%s]' % re.escape(control_chars)) def remove_control_chars(s): return control_char_re.sub('', s)</code>
此函数有效地从输入字符串中去除所有不可打印的 ASCII 字符。
或者,您可以使用 Python 内置的 string.printable 方法来过滤掉不可打印的字符。但是,此方法不包括 Unicode 字符,因此它可能不适合所有用例。
要处理 Unicode 字符,您可以在正则表达式中扩展字符类,如下所示:
<code class="python">control_chars = ''.join(map(chr, itertools.chain(range(0x00,0x20), range(0x7f,0xa0))))</code>
此扩展字符类包含基本控制字符以及常见的不可打印 Unicode 字符。
通过相应地修改remove_control_chars 函数,您可以成功处理 ASCII 和 Unicode 不可打印字符。
以上是如何从Python字符串中删除不可打印的字符?的详细内容。更多信息请关注PHP中文网其他相关文章!