python中文轉換url編碼(轉)

今天修改一個天氣預報的東西,但輸入城市不能獲得天氣預報,感受是編碼不對,由於你輸入一個城市(好比‘杭州’),url的地址編碼倒是'%E4%B8%BD%E6%B1%9F',所以需 要作一個轉換。這裏咱們就用到了模塊urllib。python

>>> import urllib
>>> data = '杭州'
>>> print data
杭州
>>> data
'\xe6\x9d\xad\xe5\xb7\x9e'
>>> urllib.quote(data)
'%E6%9D%AD%E5%B7%9E'
 ide

那咱們想轉回去呢?網站

>>> urllib.unquote('%E6%9D%AD%E5%B7%9E')
'\xe6\x9d\xad\xe5\xb7\x9e'
>>> print urllib.unquote('%E6%9D%AD%E5%B7%9E')
杭州google

細心的同窗會發現貼吧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'url


另外一種方法spa

#!/usr/bin/python
import urllib
import sys
string = sys.argv[1]
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 utf8code

相關文章
相關標籤/搜索