3 回答
TA贡献1851条经验 获得超3个赞
我得到了这个字典:
task_formatted.append(str(item['entity']))
我将其转换为 a str,然后将其附加到列表中,以便我可以轻松地将其传递给我的模板
这段代码并没有像你想象的那样做。
>>> entity = {'type': 'Asset', 'id': 1404, 'name': 'Test-Asset commé'}
>>> str(entity)
"{'type': 'Asset', 'id': 1404, 'name': 'Test-Asset comm\\xc3\\xa9'}"
当你调用str字典(或列表)时,你不会得到调用str字典的每个键和值的结果:你得到每个键和值的代表。在这种情况下,这意味着“Test-Asset commé”已以难以逆转的方式转换为“Test-Asset comm\xc3\xa9”。
>>> str(entity).decode('utf-8') # <- this doesn't work.
u"{'type': 'Asset', 'id': 1404, 'name': 'Test-Asset comm\\xc3\\xa9'}"
如果您想仅{{ item }}使用模板在模板中呈现您的字典,您可以使用 json 模块来序列化它们而不是str. 请注意,您需要将 json(类型为str)转换为unicode实例,以避免UnicodeDecodeError在呈现模板时出现 。
>>> import json
>>> template = jinja2.Template(u"""<td>{{item}}</td>""")
>>> j = json.dumps(d, ensure_ascii=False)
>>> uj = unicode(j, 'utf-8')
>>> print template.render(item=uj)
<td>{"type": "Asset", "id": 1404, "name": "Test-Asset commé"}</td>
一些一般性观察/要点:
不要使用str(或unicode) 来序列化字典或列表等容器;使用json或pickle等工具。
确保您传递给 jinja2 的任何字符串文字都是 的实例unicode,而不是str
使用 Python2 时,如果您的代码有可能处理非 ascii 值,请始终使用unicode,切勿使用str。
TA贡献1876条经验 获得超7个赞
你做错了。
<td>{{item[0].decode('utf-8')}}</td>
你为什么添加decode
?这是错误的。我建议您不要放置任何转换功能。UTF-8 可以正常工作(我认为这是默认设置)。在任何情况下,您都没有解码. 您正在将字符串编码为 UTF-8(“编码”:您使用代码 UTF-8,“解码”:从特定的编码值到语义值:实际上在 python 中,您不应该关心字符串在内部如何编码 [BTW 一种内部编码,一种 UTF-8、latin1、UTF-16 或 UTF-32,根据对整个字符串进行编码的最有效方法])。
只需删除decode('utf-8')
. 在python代码上,你不应该关心编码和解码,而应该关心输入和输出:使用三明治规则。这将极大地简化字符串、逻辑的处理,并避免大多数错误
TA贡献1744条经验 获得超4个赞
我找到了解决我的问题的方法:
unicodedata.normalize('NFKD', unicode(str(item['entity']['type']) + str(item['entity']['name']),'utf-8'))
首先,我用 str() 将我的 dict 转换为一个字符串,然后在导入 unicodedata 后我用 unicode('str' , 'utf-8') end finaly 将它转换为 UTF-8 Unicode 我使用 unicodedata.normalize()
希望它会帮助人们
添加回答
举报