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之禅

猜你喜欢

2016-12-07
好玩的Python彩蛋
2023-04-15
如何删除macOS系统默认的Python2.7并替换成最新版python3.11
2017-10-29
Python每日一题:第1题
2017-12-26
5个酷毙的Python工具
2020-12-25
PDF转换库 WeasyPrint 使用指南
2019-11-21
自己动手写个"狗屁不通"文章生成器
2014-02-10
python 函数式编程处理函数:map(),filter(),reduce()
2014-03-26
斐波那契数列(Fibonacci)递归与非递归的性能对比
2022-08-17
如何利用多态干掉 if else 语句
2017-07-19
如何正确理解@classmethod与@staticmethod