python

导航

python3如何中文转换编码?

来源 :中华考试网 2020-11-13

  处理百度贴吧的东西。想要做一个关键词的list,每次需要时,直接添加

  到list里面就可以了。但是添加到list里面是中文的情况(比如‘丽江'),url的地址编码却是'%E4%B8%BD%E6%B1%9F',因此需

  要做一个转换。这里我们就用到了模块urllib。

  >>> import urllib

  >>> data = '丽江'

  >>> print data

  丽江

  >>> data

  '\xe4\xb8\xbd\xe6\xb1\x9f'

  >>> urllib.quote(data)

  '%E4%B8%BD%E6%B1%9F'

  填写下面表单即可预约申请免费试听java课程!害怕学不会?助教全程陪读,随时解惑!担心就业?一地学习,可全国推荐就业!

  那我们想转回去呢?

  >>> urllib.unquote('%E4%B8%BD%E6%B1%9F')

  '\xe4\xb8\xbd\xe6\xb1\x9f'

  >>> print urllib.unquote('%E4%B8%BD%E6%B1%9F')

  丽江

  细心的同学会发现贴吧url中出现的是%C0%F6%BD%AD,而非'%E4%B8%BD%E6%B1%9F',其实是编码问题。百度的是gbk,其他的一般网站比如google就是utf8的。所以可以用下列语句实现。

  >>> import sys,urllib

  >>> s = '丽江'

  >>> urllib.quote(s.decode(sys.stdin.encoding).encode('gbk'))

  '%C0%F6%BD%AD'

  >>> urllib.quote(s.decode(sys.stdin.encoding).encode('utf8'))

  '%E4%B8%BD%E6%B1%9F'

  >>>

  以上就是python3中文转换url编码的方法,是不是很实用呢~毕竟中文在编程里面想转换不是一件容易的事情。

分享到

相关资讯