日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷(xiāo)解決方案
Jython中文問(wèn)題解決方法參考

Jython中文問(wèn)題:輸出中文會(huì)遇到亂碼

創(chuàng)新互聯(lián)建站專(zhuān)注于企業(yè)全網(wǎng)營(yíng)銷(xiāo)推廣、網(wǎng)站重做改版、輝縣網(wǎng)站定制設(shè)計(jì)、自適應(yīng)品牌網(wǎng)站建設(shè)、H5建站、商城網(wǎng)站開(kāi)發(fā)、集團(tuán)公司官網(wǎng)建設(shè)、外貿(mào)網(wǎng)站建設(shè)、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁(yè)設(shè)計(jì)等建站業(yè)務(wù),價(jià)格優(yōu)惠性價(jià)比高,為輝縣等各大城市提供網(wǎng)站開(kāi)發(fā)制作服務(wù)。

有Jython學(xué)習(xí)者反映說(shuō)使用Jython輸出中文字符時(shí)會(huì)遇到中文亂碼。針對(duì)Jython中文問(wèn)題,需要在在***行有一個(gè)編碼格式的聲明,寫(xiě)法可參考Python中的編碼聲明寫(xiě)法:

Python 里面的編碼和解碼也就是 unicode 和 str 這兩種形式的相互轉(zhuǎn)化。編碼是 unicode -> str,相反的,解碼就是 str -> unicode。

下面剩下的問(wèn)題就是確定何時(shí)需要進(jìn)行編碼或者解碼了,像一些庫(kù)是 unicode 版的,這樣我們?cè)趯⑦@些庫(kù)函數(shù)的返回值進(jìn)行傳輸或者寫(xiě)入文件的時(shí)候就要考慮將它編碼成合適的類(lèi)型。

關(guān)于文件開(kāi)頭的“編碼指示”,也就是 # -*- coding: -*- 這個(gè)語(yǔ)句。Python 默認(rèn)腳本文件都是 ANSCII 編碼的,當(dāng)文件中有非 ANSCII 編碼范圍內(nèi)的字符的時(shí)候就要使用“編碼指示”來(lái)修正。

關(guān)于 sys.defaultencoding,這個(gè)在解碼沒(méi)有明確指明解碼方式的時(shí)候使用。比如我有如下代碼:

 
 
 
  1. #! /usr/bin/env python 
  2. # -*- coding: utf-8 -*- 
  3. s = '中文' # 注意這里的 str 是 str 類(lèi)型的,而不是 unicode 
  4. s.encode('gb18030') 

這句代碼將 s 重新編碼為 gb18030 的格式,即進(jìn)行 unicode -> str 的轉(zhuǎn)換。因?yàn)?s 本身就是 str 類(lèi)型的,因此Python 會(huì)自動(dòng)的先將 s 解碼為 unicode ,然后再編碼成 gb18030。因?yàn)榻獯a是python自動(dòng)進(jìn)行的,我們沒(méi)有指明解碼方式,python 就會(huì)使用 sys.defaultencoding 指明的方式來(lái)解碼。很多情況下 sys.defaultencoding 是ANSCII,如果 s 不是這個(gè)類(lèi)型就會(huì)出錯(cuò)。

拿上面的情況來(lái)說(shuō),我的 sys.defaultencoding 是 anscii,而 s 的編碼方式和文件的編碼方式一致,是 utf8 的,所以出錯(cuò)了:

UnicodeDecodeError: 'ascii' codec can't decode byte 0xe4 in position

0: ordinal not in range(128)

對(duì)于這種情況,我們有兩種方法來(lái)改正錯(cuò)誤:

一是明確的指示出 s 的編碼方式

 
 
 
  1. #! /usr/bin/env python 
  2. # -*- coding: utf-8 -*- 
  3. s = '中文' 
  4. s.decode('utf-8').encode('gb18030') 

二是更改 sys.defaultencoding 為文件的編碼方式

 
 
 
  1. #! /usr/bin/env python 
  2. # -*- coding: utf-8 -*- 
  3. import sys 
  4. reload(sys) # Python2.5 初始化后會(huì)刪除 sys.setdefaultencoding 這個(gè)方法,我們需要重新載入 
  5. sys.setdefaultencoding('utf-8') 
  6. str = '中文' 
  7. str.encode('gb18030')

這樣應(yīng)該可以解決Jython中文亂碼的問(wèn)題了。


分享名稱(chēng):Jython中文問(wèn)題解決方法參考
網(wǎng)頁(yè)地址:http://www.5511xx.com/article/cdgiggg.html