>>> 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'

本文介绍了如何使用Python的urllib库进行URL编码与解码操作,包括不同编码方式间的转换,如从UTF-8到GBK,并提供了具体的代码示例。
4829

被折叠的 条评论
为什么被折叠?



