本篇文章主要介绍了python实现中文及其他字符转换url编码的方法,结合实例形式分析了Python针对中文的gbk与utf-8编码转换的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
今天做一个外贸电商网站上的商品明细。想要做一个关键词的查询,输入的是当地小语种,例如(túi đựng hộp cơm),但是却出现编码错误问题,因此需要做一个转换。这里我们就用到了模块urllib。
import urllib.parse
data = "túi đựng hộp cơm"
new_data = urllib.parse.quote(data)
print('new_data:',new_data)
# 其结果是:
't%C3%BAi%20%C4%91%E1%BB%B1ng%20h%E1%BB%99p%20c%C6%A1m'
之后再拼接回url,链接正常访问,完美。
需要注意的是,当前使用的是python3,在python3中,urllib模块的quote是在parse中的。而python2中的quote是直接在urllib中的。
import urllib
data = "香港历史博物馆"
data = urllib.quote(data)
print(data)
那如果想要转回去呢?
import urllib.parse
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一下,完美解决。