We have:
>>> str
'exit\r\ndrwxr-xr-x 2 root root 0 Jan 1 2000
\x1b[1;34mbin\x1b[0m\r\ndrwxr-xr-x 3 root root
0 Jan 1 2000 \x1b[1;34mlib\x1b[0m\r\ndrwxr-xr-x 10 root
root 0 Jan 1 1970 \x1b[1;34mlocal\x1b[0m\r\ndrwxr-xr-x
2 root root 0 Jan 1 2000 \x1b[1;34msbin\x1b[0m\r\ndrwxr-xr-x
5 root root 0 Jan 1 2000 \x1b[1;34mshare\x1b[0m\r\n# exit\r\n'
>>> print str
exit
drwxr-xr-x 2 root root 0 Jan 1 2000 bin
drwxr-xr-x 3 root root 0 Jan 1 2000 lib
drwxr-xr-x 10 root root 0 Jan 1 1970 local
drwxr-xr-x 2 root root 0 Jan 1 2000 sbin
drwxr-xr-x 5 root root 0 Jan 1 2000 share
# exit
我想使用正则表达式摆脱所有 '\xblah[0m' 废话。我试过了
re.sub(str, r'(\x.*m)', '')
但这并没有达到目的。有任何想法吗?
你有几个问题:
-
您以错误的顺序将参数传递给 re.sub 。它应该是:
re.sub(regexp_pattern,替换,source_string)
该字符串不包含“\x”。 “\x1b”是转义字符,它是单个字符。
正如 interjay 指出的,你想要“.*?”而不是“.*”,因为否则它将匹配从第一个转义符到最后一个“m”的所有内容。
对 re.sub 的正确调用是:
print re.sub('\x1b.*?m', '', s)
或者,您可以使用:
print re.sub('\x1b[^m]*m', '', s)
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)