首页 >后端开发 >Python教程 >如何从Python字符串中删除不可打印的字符?

如何从Python字符串中删除不可打印的字符?

Patricia Arquette
Patricia Arquette原创
2024-10-22 06:57:02447浏览

How to Remove Non-Printable Characters from Strings in Python?

从 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中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn