python將unicode和str互相轉(zhuǎn)化的實(shí)現(xiàn)
問題一:
將u’u810fu4e71’轉(zhuǎn)換為’u810fu4e71’
方法:
s_unicode = u’u810fu4e71’s_str = s_unicode.encode(’unicode-escape’).decode(’string_escape’)
問題二:
將’u810fu4e71’轉(zhuǎn)換為u’u810fu4e71’
方法:
s_str = ’u810fu4e71’s_unicode = s_str.decode(’unicode-escape’)
補(bǔ)充知識(shí):Python最簡(jiǎn)單的解決列表中只打印UNICODE而不是中文字符的方法
答案就是用json模塊:
例如:
import json data=[{u’u663eu793a’: [u’python’, u’u8bd5u9a8c’], u’u6570u91cf’: 22, u’u8bedu8a00’: u’python’}]data_c = u’u663eu793a’print dataprint data_c res_data=json.dumps(data,ensure_ascii=False,encoding='gb2312')print res_data
在沒有進(jìn)行格式轉(zhuǎn)換時(shí),輸出為:
>>>[{u’u663eu793a’: [u’python’, u’u8bd5u9a8c’], u’u6570u91cf’: 22, u’u8bedu8a00’: u’python’}]
>>>顯示
可見非列表中的數(shù)據(jù)在輸出時(shí)是會(huì)轉(zhuǎn)換成中文顯示出來的,但列表中的unicode數(shù)據(jù)不會(huì)。
轉(zhuǎn)換后,輸出為:
>>>[{'顯示': ['python', '試驗(yàn)'], '數(shù)量': 22, '語言': 'python'}]
如果后面這種輸出是想要的格式,那么就利用現(xiàn)成的json模塊將原列表格式轉(zhuǎn)換為json字符串輸出,并設(shè)置好編碼格式,就可以了。
當(dāng)還需要再用這部分用來顯示的數(shù)據(jù),譬如以后什么時(shí)候又想直接用python來讀取log文件中這種看起來比較方便的帶中文的偽列表,那么再用json.loads轉(zhuǎn)換回去即可。
以上這篇python將unicode和str互相轉(zhuǎn)化的實(shí)現(xiàn)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. python 實(shí)現(xiàn)在無序數(shù)組中找到中位數(shù)方法2. python中復(fù)數(shù)的共軛復(fù)數(shù)知識(shí)點(diǎn)總結(jié)3. ASP動(dòng)態(tài)網(wǎng)頁制作技術(shù)經(jīng)驗(yàn)分享4. HTML DOM setInterval和clearInterval方法案例詳解5. idea重置默認(rèn)配置的方法步驟6. PHP中file_get_contents設(shè)置header請(qǐng)求頭,curl傳輸選項(xiàng)參數(shù)詳解說明7. jsp網(wǎng)頁實(shí)現(xiàn)貪吃蛇小游戲8. 愛因斯坦謎題的java解答方法9. html清除浮動(dòng)的6種方法示例10. Springboot整合camunda+mysql的集成流程分析
