xiaowei8782088 发表于 2018-8-10 09:33:25

python中文转换url编码(转)

  今天修改一个天气预报的东西,但输入城市不能得到天气预报,感觉是编码不对,因为你输入一个城市(比如‘杭州’),url的地址编码却是'%E4%B8%BD%E6%B1%9F',因此需 要做一个转换。这里我们就用到了模块urllib。
  >>> import urllib
  >>> data = '杭州'
  >>> print data
  杭州
  >>> data
  '\xe6\x9d\xad\xe5\xb7\x9e'
  >>> urllib.quote(data)
  '%E6%9D%AD%E5%B7%9E'
  那我们想转回去呢?
  >>> urllib.unquote('%E6%9D%AD%E5%B7%9E')
  '\xe6\x9d\xad\xe5\xb7\x9e'
  >>> print urllib.unquote('%E6%9D%AD%E5%B7%9E')
  杭州
  细心的同学会发现贴吧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'))
  %BA%BC%D6%DD
  >>> urllib.quote(s.decode(sys.stdin.encoding).encode('utf8'))
  '%E6%9D%AD%E5%B7%9E'
  另一种方法
  #!/usr/bin/python
  import urllib
  import sys
  string = sys.argv
  string = unicode(string,"gbk")
  utf8_string = string.encode("utf-8")
  gbk_string=string.encode("gbk")
  gbk=urllib.quote(gbk_string)
  utf8=urllib.quote(utf8_string)
  print gbk
  print utf8
页: [1]
查看完整版本: python中文转换url编码(转)