Python3中文转换URL编码

这篇文章主要介绍了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

相关文章
相关标签/搜索