如何使用python3解码utf-16中存在的字符串
"b'\\xff\\xfeS\\x00H\\x00A\\x00D\\x00E\\x00K\\x00 \\x00D\\x00E\\x00E\\x00E\\x00P\\x00'"
尝试了此操作,但收到错误TypeError:需要一个类似字节的对象,而不是'str'
a.rstrip("\n").decode("utf-16")
最佳答案
您有一个字符串,该字符串是通过对编码文本(bytes实例)调用str
创建的。像这样:
>>> s = 'abc'
>>> bs = s.encode('utf-16')
>>> bs
b'\xff\xfea\x00b\x00c\x00'
>>> str(bs)
"b'\\xff\\xfea\\x00b\\x00c\\x00'" # <- the 'b' is *inside* the outer quotes
可以通过在字符串上调用ast.literal_eval来恢复字节,然后可以通过调用其解码方法将字节解码回sring。
>>> import ast
>>> s = "b'\\xff\\xfeS\\x00H\\x00A\\x00D\\x00E\\x00K\\x00 \\x00D\\x00E\\x00E\\x00E\\x00P\\x00'"
>>> bs = ast.literal_eval(s)
>>> bs
b'\xff\xfeS\x00H\x00A\x00D\x00E\x00K\x00 \x00D\x00E\x00E\x00E\x00P\x00'
>>> original = bs.decode('utf-16')
>>> original
'SHADEK DEEEP'
这是一种解决方法。正确的解决方案是首先防止在字节实例上调用
str
。