这篇文章主要介绍了python实现中文转换url编码的方法,结合实例形式分析了Python针对中文的gbk与utf-8编码转换的相关技巧,具备必定参考借鉴价值,须要的朋友能够参考下python
今天要作一个艺术网站上的东西。想要作一个关键词的查询,输入的是中文,例如(香港历史博物馆),可是却出现编码错误问题,所以需 要作一个转换。这里咱们就用到了模块urllib。网站
import url lib data = "香港历史博物馆" data = urllib.parse.quote(data) print(data) # 其结果是: '%E9%A6%99%E6%B8%AF%E5%8E%86%E5%8F%B2%E5%8D%9A%E7%89%A9%E9%A6%86'
Ok了。编码
须要注意的是,为使用的是python3,在python3中,urllib模块的quote是在parse中的。而python2中的quote是直接在urllib中的。url
import url lib data = "香港历史博物馆" data = urllib.quote(data) print(data)
那咱们想转回去呢?code
data = urllib.parse.unquote('%E9%A6%99%E6%B8%AF%E5%8E%86%E5%8F%B2%E5%8D%9A%E7%89%A9%E9%A6%86') print(data) # 结果是: '香港历史博物馆'
有些网站,他们的编码并非utf8,也许是gbk,或者什么其余的,这个时候,转换出来的所需url编码可能就不是'%E9%A6%99%E6%B8%AF%E5%8E%86%E5%8F%B2%E5%8D%9A%E7%89%A9%E9%A6%86'
这样的了,而是'%CF%E3%B8%DB%C0%FA%CA%B7%B2%A9%CE%EF%B9%DD'
相似这样的(这是gbk的)。那么,咱们怎么办呢?utf-8
很简单。class
urllib.parse.quote(data.encode('gbk'))
是否是很简单,在转换以前,先encode一下,完美解决。import