urllib模块中parse函数中的urlencode和quote_plus方法

Posted zzy0306

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了urllib模块中parse函数中的urlencode和quote_plus方法相关的知识,希望对你有一定的参考价值。

本来只是向看一下quote_plus的作用,然后发现urlencode方法也是很方便的一个组合字符串的方法首先是介绍一下urlencode,他是将一些传入的元素使用&串联起来,效果如下:

>>>params = {
            "appid": 1,
            "mch_id": 1,
            "body": 1,
            "out_trade_no": 1,
            "total_fee": 1,
            "spbill_create_ip": 1,
            "notify_url": 1,
            "trade_type": 1,
            "nonce_str": 1
        }
>>>parse.urlencode(params)
appid=1&mch_id=1&body=1&out_trade_no=1&total_fee=1&spbill_create_ip=1&notify_url=1&trade_type=1&nonce_str=1

如果加以改造,就可以直接应到生成微信支付的拼接字符串当中了:

>>>parse.urlencode([(k, params[k]) for k in sorted(params)])
appid=1&body=1&mch_id=1&nonce_str=1&notify_url=1&out_trade_no=1&spbill_create_ip=1&total_fee=1&trade_type=1
>>>[(k, params[k]) for k in sorted(params)]
[(appid, 1), (body, 1), (mch_id, 1), (nonce_str, 1), (notify_url, 1), (out_trade_no, 1), (spbill_create_ip, 1), (total_fee, 1), (trade_type, 1)]

然后就是quote_plus了,使用了一下发现这个方法是将一些特殊的字符串转换为固定的一些符号字母数字组合,例如:

>>>parse.quote_plus(a&b/c)
a%26b%2Fc

其中的&和/都分别变为了%26b和%2F,还有更多的一些符号变化就先不去一一尝试了。

以上是关于urllib模块中parse函数中的urlencode和quote_plus方法的主要内容,如果未能解决你的问题,请参考以下文章

Python,与函数urllib.urlencode相反

AttributeError:模块 'urllib' 没有属性 'parse'

没有名为 urllib.parse 的模块(我应该如何安装它?)

urllib模块

爬虫--urllib模块

Python3标准库:urllib.parse分解URL