本文实例讲述了python实现中文转换url编码的方法。分享给大家供大家参考,具体如下:
今天要处理百度贴吧的东西。想要做一个关键词的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\'
那我们想转回去呢?
>>> 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\' >>>
更多关于Python相关内容感兴趣的读者可查看本站专题:《Python图片操作技巧总结》、《Python数据结构与算法教程》、《Python Socket编程技巧总结》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》、《Python入门与进阶经典教程》及《Python文件与目录操作技巧汇总》
希望本文所述对大家Python程序设计有所帮助。