给定如下的URL,如何解析查询参数的值?例如,在本例中,我想要some_key的值。

/some_path?some_key=some_value'

我在我的环境中使用Django;请求对象上是否有可以帮助我的方法?

我尝试使用self.request.get('some_key'),但它没有返回值some_value,因为我希望。


当前回答

有一个很好的库w3lib.url

from w3lib.url import url_query_parameter
url = "/abc?def=ghi"
print url_query_parameter(url, 'def')
ghi

其他回答

我发现对于Tornado的用户来说没有答案:

key = self.request.query_arguments.get("key", None)

此方法必须在派生自以下处理程序的处理程序中工作:

tornado.web.RequestHandler

当无法找到所请求的键时,此方法将返回None。这为您节省了一些异常处理。

有一个很好的库w3lib.url

from w3lib.url import url_query_parameter
url = "/abc?def=ghi"
print url_query_parameter(url, 'def')
ghi

没有使用Django,尝试使用Python 3.9。它也可以在处理程序中使用下面的代码片段来检索:

考虑URL为-

http://localhost:8081/api/v1/users?query_key=abcdef12345

和handler方法为:

@routes.get('/api/v1/users')
async def handler_users(request):
    query_key = request.url.query['query_key']

我很惊讶这个答案还没出现在这里。使用:

request.GET.get('variable_name')

这将从“get”字典中“获取”变量,如果它存在则返回“variable_name”值,如果不存在则返回None对象。

import urlparse
url = 'http://example.com/?q=abc&p=123'
par = urlparse.parse_qs(urlparse.urlparse(url).query)

print par['q'][0], par['p'][0]