我想从字符串列表中删除所有类型的转义序列。我怎样才能做到这一点? 输入:
['william', 'short', '\x80', 'twitter', '\xaa', '\xe2', 'video', 'guy', 'ray']
输出:
['william', 'short', 'twitter', 'video', 'guy', 'ray']
http://docs.python.org/reference/lexical_analysis.html#string-literals
答案 0 :(得分:24)
如果您想删除一些您不喜欢的字符,可以使用translate功能删除它们:
>>> s="\x01\x02\x10\x13\x20\x21hello world"
>>> print(s)
!hello world
>>> s
'\x01\x02\x10\x13 !hello world'
>>> escapes = ''.join([chr(char) for char in range(1, 32)])
>>> t = s.translate(None, escapes)
>>> t
' !hello world'
这将删除所有这些控制字符:
001 1 01 SOH (start of heading)
002 2 02 STX (start of text)
003 3 03 ETX (end of text)
004 4 04 EOT (end of transmission)
005 5 05 ENQ (enquiry)
006 6 06 ACK (acknowledge)
007 7 07 BEL '\a' (bell)
010 8 08 BS '\b' (backspace)
011 9 09 HT '\t' (horizontal tab)
012 10 0A LF '\n' (new line)
013 11 0B VT '\v' (vertical tab)
014 12 0C FF '\f' (form feed)
015 13 0D CR '\r' (carriage ret)
016 14 0E SO (shift out)
017 15 0F SI (shift in)
020 16 10 DLE (data link escape)
021 17 11 DC1 (device control 1)
022 18 12 DC2 (device control 2)
023 19 13 DC3 (device control 3)
024 20 14 DC4 (device control 4)
025 21 15 NAK (negative ack.)
026 22 16 SYN (synchronous idle)
027 23 17 ETB (end of trans. blk)
030 24 18 CAN (cancel)
031 25 19 EM (end of medium)
032 26 1A SUB (substitute)
033 27 1B ESC (escape)
034 28 1C FS (file separator)
035 29 1D GS (group separator)
036 30 1E RS (record separator)
037 31 1F US (unit separator)
答案 1 :(得分:11)
这样的东西?
>>> from ast import literal_eval
>>> s = r'Hello,\nworld!'
>>> print(literal_eval("'%s'" % s))
Hello,
world!
编辑:好的,这不是你想要的。你想要什么一般不能做,因为正如@Sven Marnach所解释的那样,字符串实际上并不包含转义序列。这些只是字符串文字中的符号。
您可以使用
过滤列表中包含非ASCII字符的所有字符串def is_ascii(s):
try:
s.decode('ascii')
return True
except UnicodeDecodeError:
return False
[s for s in ['william', 'short', '\x80', 'twitter', '\xaa',
'\xe2', 'video', 'guy', 'ray']
if is_ascii(s)]
答案 2 :(得分:3)
您可以使用列表理解和str.isalnum()
过滤掉不是字母数字的“字词”:
>>> l = ['william', 'short', '\x80', 'twitter', '\xaa', '\xe2', 'video', 'guy', 'ray']
>>> [word for word in l if word.isalnum()]
['william', 'short', 'twitter', 'video', 'guy', 'ray']
如果您希望过滤掉数字,请改用str.isalpha()
:
>>> l = ['william', 'short', '\x80', 'twitter', '\xaa', '\xe2', 'video', 'guy', 'ray', '456']
>>> [word for word in l if word.isalpha()]
['william', 'short', 'twitter', 'video', 'guy', 'ray']
答案 3 :(得分:2)
这是不可能的,至少在你要求的广泛范围内。正如其他人所提到的,运行时python不知道具有转义序列的东西与没有转义序列的东西之间的区别。
示例:
print ('\x61' == 'a')
打印True
。所以除非你尝试对python脚本进行一些静态分析,否则无法找到这两个字符串之间的区别。
答案 4 :(得分:0)
从hexadimal转换为String时,我遇到了类似的问题。这是最终在python中运行的 实施例
list_l = ['william', 'short', '\x80', 'twitter', '\xaa', '\xe2', 'video', 'guy', 'ray']
decode_data=[]
for l in list_l:
data =l.decode('ascii', 'ignore')
if data != "":
decode_data.append(data)
# output :[u'william', u'short', u'twitter', u'video', u'guy', u'ray']
答案 5 :(得分:0)
以下内容在Python 3.6中为我工作:
word = '\t\t\t\t\t\ntest\t msg'
filter = ''.join([chr(i) for i in range(1, 32)])
word.translate(str.maketrans('', '', filter))
输出:
'test msg'
来源here