python中文转换url编码(转)

发布时间:2019-09-05 07:06:52编辑:auto阅读(1773)

    今天修改一个天气预报的东西,但输入城市不能得到天气预报,感觉是编码不对,因为你输入一个城市(比如‘杭州’),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[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 utf8

关键字