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-11-21
自己动手写个"狗屁不通"文章生成器
2019-02-22
Python不行了?
2019-05-13
python3判断list是否为空
2018-10-15
提升逼格的两个函数:setdefault 与 defaultdict
2017-10-29
Python每日一题:第1题
2016-09-18
分析urllib.unquote乱码的原因
2017-07-01
Python是怎么火起来的
2017-10-22
图解Python变量与赋值
2020-01-01
Python2.7: 2020年4月还会发布一个版本
2019-05-16
命名难,难于上青天