亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

Unicode 錯誤燒瓶 jinja2

Unicode 錯誤燒瓶 jinja2

至尊寶的傳說 2021-12-09 18:13:34
我希望在燒瓶上創建一個帶有 python 的網頁,一切都很好,我強烈推薦燒瓶。但是當涉及到 Unicode et 編碼時,它在 python 網頁等之間總是很困難。所以我有一個表格,我在特定的燒瓶路線上發布,我得到了我的價值,我需要做一些小包裝來讓我的變量井井有條。我得到了這個字典:            task_formatted.append(str(item['entity']))我將它轉換為 str 然后我將它附加到一個列表中,這樣我就可以輕松地將它傳遞給我的模板我希望 str 在網頁 python 頁面上呈現為 UTF-8:  # -*- coding: utf-8 -*- html頁面:  <meta charset="utf-8"/>然后我使用 jinja 在我的頁面中打印它們:            {% for item in task %}            <tr>              <td>{{item[0].decode('utf-8')}}</td>              <td>{{item[1].decode('utf-8')}}</td>              <td>{{item[2]}}</td>              <td>{{item[3]}}</td>              <td>{{item[4]}}</td>              <td><button id="taskmodal1"></td>            </tr>            {% endfor %}但是我的 item[0].decode('utf-8') 和我的 item[1].decode('utf-8')正在打?。簕'type': 'Asset', 'id': 1404, 'name': 'Test-Asset comm\xc3\xa9'}代替{'type': 'Asset', 'id': 1404, 'name': 'Test-Asset commé}我已經在 python 端使用 .encode('utf-8') 嘗試了幾種方法,使用 unicode(str) 和 render_template().encode('utf-8') 而我的想法越來越少。公平地說,我認為它們是我對 Unicode 不理解的東西,所以我想得到一些解釋(不是文檔鏈接,因為我很可能已經閱讀了它們)或一些解決方案來讓它工作,對于我的程序能夠正確編寫 str 非常重要,我在 js http 調用后使用了它。謝謝PS:我使用的是python2
查看完整描述

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。


查看完整回答
反對 回復 2021-12-09
?
幕布斯6054654

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代碼上,你不應該關心編碼和解碼,而應該關心輸入和輸出:使用三明治規則。這將極大地簡化字符串、邏輯的處理,并避免大多數錯誤


查看完整回答
反對 回復 2021-12-09
?
慕無忌1623718

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()

希望它會幫助人們


查看完整回答
反對 回復 2021-12-09
  • 3 回答
  • 0 關注
  • 191 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號