Python3中文转换URL编码

这篇文章主要介绍了python实现中文转换url编码的方法,结合实例形式分析了Python针对中文的gbk与utf-8编码转换的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下

今天要做一个艺术网站上的东西。想要做一个关键词的查询,输入的是中文,例如(香港历史博物馆),但是却出现编码错误问题,因此需 要做一个转换。这里我们就用到了模块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中的。

import url lib

data = "香港历史博物馆"

data = urllib.quote(data)

print(data)

那我们想转回去呢?

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的)。那么,我们怎么办呢?

很简单。

urllib.parse.quote(data.encode('gbk'))

是不是很简单,在转换之前,先encode一下,完美解决。

猜你喜欢

转载自my.oschina.net/u/3826227/blog/1821331