Python如何提取url中的参数

By 刘志军, 2019-05-07, 分类: qa

python

如何用 Python 提取URL中的参数,例如:

http://foofish.net?q=python&k=java 

提取其中的参数为字典对象

{
    "q": "python",
    "k": "java"
}

可以使用 urlib.parse 模块中的 urlpase 类来实现

>>> import urllib.parse as urlparse
>>> url = 'http://foofish.net?q=python&k=java'
>>> parsed = urlparse.urlparse(url)
>>> parsed
ParseResult(scheme='http', netloc='foofish.net', path='', params='', query='q=python&k=java', fragment='')

>>> querys = urlparse.parse_qs(parsed.query)
>>> querys
{'q': ['python'], 'k': ['java']}
>>> querys = {k: v[0] for k, v in querys.items()}
>>> querys
{'q': 'python', 'k': 'java'}

parsed 是一个tuple对象,把url分成了6个部分,query 属性就是查询参数部分,再通过 prase_qs 方法解析成字典对象,解析后,字典的value 是列表,因为同一个参数可以有多个值,我们只取第一个值。


有问题可以扫描二维码和我交流

关注公众号「Python之禅」,回复「1024」免费获取Python资源

python之禅

猜你喜欢

2019-04-25
命令行神器 Click 快速上手
2014-02-17
Python多线程编程
2017-05-15
一步一步教你认识Python闭包
2013-10-30
Python“不为人知的”特性
2019-05-13
python3判断list是否为空
2017-08-01
Python 2 和 Python 3 主要区别有哪些(一)?
2019-02-22
Python不行了?
2017-07-19
如何正确理解@classmethod与@staticmethod
2017-12-26
5个酷毙的Python工具
2017-09-01
关于操作 Python 列表最常见的10个问答