Python3 中文等其他字符 转换百分号% URL编码格式_汉字转%-CSDN博客

Python3 中文等其他字符 转换百分号% URL编码格式

本篇文章主要介绍了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一下,完美解决。

  • 4
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值