Python3编码解码url
python2和python3对于url的解码和编码
某天做爬虫时遇到一个post请求的参数是编码过的字符串如下,看不懂,初步判断可能是url编码
str = "%7B%22ShoppingToken%22%3A%22NewAirChina%257CCA4173%252C1%252C%252C12-CA989%252C1%252C%252C12%257CY%252CV%252C-Y%252CV%252C%257C0%257C3430%252C1564%252CCAGJ-CA%257CNOR%257C%22%2C%22Eligibility%22%3A%22NOR%22%7D"
对于不了解url编码,解码的同学,我简单解释一下,也可以参考 http://www.w3school.com.cn/tags/html_ref_urlencode.html
URL为何要编码、解码?
通常如果一样东西需要编码,说明这样东西并不适合传输。原因多种多样,如Size过大,包含隐私数据。对于Url来说,之所以要进行编码,是因为Url中有些字符会引起歧义。
例如,Url参数字符串中使用key=value键值对这样的形式来传参,键值对之间以&符号分隔,如/s?q=abc&ie=utf-8。如果你的value字符串中包含了=或者&,那么势必会造成接收Url的服务器解析错误,因此必须将引起歧义的&和=符号进行转义,也就是对其进行编码。
又如,Url的编码格式采用的是ASCII码,而不是Unicode,这也就是说你不能在Url中包含任何非ASCII字符,例如中文。否则如果客户端浏览器和服务端浏览器支持的字符集不同的情况下,中文可能会造成问题。
百度了一下python解码url找到了解决办法,感谢 https://blog.csdn.net/junli_chen/article/details/50060161
直接把代码贴过来
#url编码: import urllib url = 'http://test.com/s?wd=哈哈' #如果此网站编码是gbk的话,需要进行解码,从gbk解码成unicode,再从Unicode编码编码为utf-8格式。 url = url.decode('gbk', 'replace') print urllib.quote(url.encode('utf-8', 'replace')) #结果: http%3a%2f%2ftest.com%2fs%3fwd%3d%e5%93%88%e5%93%88 #url解码: import urllib encoded_url = 'http%3a%2f%2ftest.com%2fs%3fwd%3d%e5%93%88%e5%93%88' print urllib.unquote(encoded_url).decode('utf-8', 'replace').encode('gbk', 'replace') #反过来
使用了python2的语法,我使用的python3,所以改了一下语法,发现还不好使,quote报错了
查了查资料原来python3中qutoe和unqutoe被放到了urllib.parse中(python2是在urllib中)
下面贴上python3解码编码的代码:
#解码 from urllib import parse encoded_url = '%7B%22ShoppingToken%22%3A%22NewAirChina%257CCA4173%252C1%252C%252C12-CA989%252C1%252C%252C12%257CY%252CV%252C-Y%252CV%252C%257C0%257C3430%252C1564%252CCAGJ-CA%257CNOR%257C%22%2C%22Eligibility%22%3A%22NOR%22%7D' print(parse.unquote(encoded_url)
#编码
from urllib import parse url = '{"ShoppingToken":"NewAirChina%7CCA4173%2C1%2C%2C12-CA989%2C1%2C%2C12%7CY%2CV%2C-Y%2CV%2C%7C0%7C3430%2C1564%2CCAGJ-CA%7CNOR%7C","Eligibility":"NOR"}' print(parse.quote(url))
解码完成发现还有 %&%2之类的没关系,我们把未解密的字符串拿出来再来一次
python2的代码可以参考上面,因为我没装python2,有兴趣的可以自己试一试
- Python接口自动化--URL参数的编码和解码 6
- Python2.x 利用urllib.quote实现url地址编码解码
- python中对URL的编码与解码
- python对URL的编码和解码
- JS中encodeURIComponent(URL)编码与decodeURIComponent(URL)解码详解
- python 解码base64编码邮件
- URL 编码与解码和escape,encodeURI,encodeURIComponet用法
- js对url进行编码和解码(三种方式区别)
- Python2.X UNICODE编码解码
- Python URL编解码 encodeURIComponent
- JavaScript对浏览器的URL进行编码、解码
- JAVA工具类之URL(编码、解码、参数解析)
- iOS URL中汉字的编码和解码
- Python3.X Socket 一个编码与解码的坑
- python中的编码与解码
- Python中json格式数据的编码和解码
- JS对URL进行编码和解码(三种方式区别)
- ios url 编码和解码
- ios url 编码和解码
- python 编码与解码 decode解码 encode 编码