如何在Python中正确编码?
我是python新手,我正在努力进行编码 我有一个字符串列表,如下所示:如何在Python中正确编码?,python,unicode,utf-8,encode,Python,Unicode,Utf 8,Encode,我是python新手,我正在努力进行编码 我有一个字符串列表,如下所示: keys = ["u'part-00000-6edc0ee4-de74-4f82-9f8c-b4c965896224-c000.csv'", " u'part-00001-6edc0ee4-de74-4f82-9f8c-b4c965896224-c000.csv'"] 我这样做是为了编码 keys = [x.encode('UTF-8') for x in keys] 然而,我得到“b”附加,结果是
keys = ["u'part-00000-6edc0ee4-de74-4f82-9f8c-b4c965896224-c000.csv'",
" u'part-00001-6edc0ee4-de74-4f82-9f8c-b4c965896224-c000.csv'"]
我这样做是为了编码
keys = [x.encode('UTF-8') for x in keys]
然而,我得到“b”附加,结果是
[b"u'part-00000-6edc0ee4-de74-4f82-9f8c-b4c965896224-c000.csv'",
b" u'part-00001-6edc0ee4-de74-4f82-9f8c-b4c965896224-c000.csv'"]
我想用utf-8编码会更简单
我做错了什么?您应该首先尝试修复用于获取原始字符串列表的方法,但如果您对此没有控制权,则可以使用以下方法:
>>> import ast
>>> [ast.literal_eval(i.strip()) for i in keys]
结果应该是
[u'part-00000-6edc0ee4-de74-4f82-9f8c-b4c965896224-c000.csv',
u'part-00001-6edc0ee4-de74-4f82-9f8c-b4c965896224-c000.csv']
对于Python 2,以及
['part-00000-6edc0ee4-de74-4f82-9f8c-b4c965896224-c000.csv',
'part-00001-6edc0ee4-de74-4f82-9f8c-b4c965896224-c000.csv']
对于Python 3。这是否回答了您的问题?你最初是如何得到原始的字符串列表的?看起来一系列转换的结果出了问题。这也是Python2还是python3?它的python3,我从外部源代码获得,我无法控制它