华南俳烁实业有限公司

python

當(dāng)前位置:中華考試網(wǎng) >> python >> python教程 >> 文章內(nèi)容

python3怎樣改變默認(rèn)的ascii編碼?

來源:中華考試網(wǎng)  [2020年11月27日]  【

  我們都知道很多軟件里會自帶一些工具,大部分使用起來還是比較順手的,但是總會遇到一些不好用的工具,這時候我們就需要找一些其他的方法替換一下。提到utf-8小伙伴們肯定不陌生,我們在之前的文章中有反復(fù)提及。python的字符串默認(rèn)的的是另一種編碼,很多人還是喜歡用utf-8,所以今天小編教大家改變默認(rèn)的ascii編碼方法。

  Python默認(rèn)字符串采用的是ascii編碼方式,如下所示:

  python -c "import sys; print sys.getdefaultencoding()"

  Ascii

  可以通過#coding:utf-8 指定頁面默認(rèn)編碼為utf-8(ps:但系統(tǒng)默認(rèn)還是ascii)

  字符串的編解碼都是以unicode為中間編碼,無法直接完成轉(zhuǎn)換,python會自動按其系統(tǒng)默認(rèn)編碼方式解碼為unicode,再編碼成另一中編碼格式

  比如:

  #coding:utf-8

  s = '中文'

  print s.decode('gbk')

  報錯解決:

  #!/usr/bin/python

  # -*- coding: utf-8 -*-

  import sys

python課程免費試聽預(yù)約

  • 地區(qū):
  • 姓名:
  • 手機:

  # reload(sys)

  # sys.setdefaultencoding('utf-8')

  s = '中文'

  print [s]

  print s.encode('gbk')

  此時報錯為UnicodeDecodeError: 'ascii' codec can't decode byte 0xe4 in position 0: ordinal not in range(128) 猜測雖然指定了當(dāng)前頁面為utf-8,但因為直接encode()轉(zhuǎn)換程序會自動先按照系統(tǒng)默認(rèn)的編碼(此時還是ascii) decode一次成unicode,再從unicode編碼為gbk, 因為s編碼為utf-8,明顯解碼出錯

  有兩種解決辦法

  1 手動解碼 print s.decode(‘utf-8’).encode(‘gbk’)

  2 改變系統(tǒng)默認(rèn)編碼,即加入這兩句

  reload(sys)

  sys.setdefaultencoding('utf-8')

  相信看完本篇文章后,我們已經(jīng)學(xué)會把默認(rèn)字符串采用的ascii編碼換成utf-8了,相信后者大家使用起來更為順手。

責(zé)編:fushihao

上一篇:python中subprocess模塊如何被替換?

下一篇: 沒有了

  • 會計考試
  • 建筑工程
  • 職業(yè)資格
  • 醫(yī)藥考試
  • 外語考試
  • 學(xué)歷考試
唐山市| 东至县| 时尚| 乐东| 浦县| 阿荣旗| 隆林| 故城县| 鹤庆县| 建瓯市| 寿阳县| 东山县| 当阳市| 江安县| 和硕县| 罗源县| 耒阳市| 色达县| 布拖县| 延长县| 惠水县| 盐津县| 德江县| 平顶山市| 沂源县| 鸡西市| 贵德县| 云龙县| 江口县| 大庆市| 班玛县| 赤壁市| 克拉玛依市| 台湾省| 湖北省| 米泉市| 齐齐哈尔市| 天峻县| 池州市| 原阳县| 武隆县|