给定如下的URL,如何解析查询参数的值?例如,在本例中,我想要some_key的值。
/some_path?some_key=some_value'
我在我的环境中使用Django;请求对象上是否有可以帮助我的方法?
我尝试使用self.request.get('some_key'),但它没有返回值some_value,因为我希望。
给定如下的URL,如何解析查询参数的值?例如,在本例中,我想要some_key的值。
/some_path?some_key=some_value'
我在我的环境中使用Django;请求对象上是否有可以帮助我的方法?
我尝试使用self.request.get('some_key'),但它没有返回值some_value,因为我希望。
当前回答
import cgitb
cgitb.enable()
import cgi
print "Content-Type: text/plain;charset=utf-8"
print
form = cgi.FieldStorage()
i = int(form.getvalue('a'))+int(form.getvalue('b'))
print i
其他回答
在原始python中解析它:
path = '/some_path?k1=v1&k2=v2&k3=v3'
_, query_string = path.split('?')
params = dict(param.split('=') for param in query_string.split('&'))
print(params)
输出:
{'k1': 'v1', 'k2': 'v2', 'k3': 'v3'}
有一个很好的库w3lib.url
from w3lib.url import url_query_parameter
url = "/abc?def=ghi"
print url_query_parameter(url, 'def')
ghi
顺便说一句,我有使用parse_qs()和获得空值参数的问题,并了解到您必须通过第二个可选参数“keep_blank_values”来返回查询字符串中不包含值的参数列表。默认为false。一些蹩脚的api需要参数,即使它们不包含任何值
for k,v in urlparse.parse_qs(p.query, True).items():
print k
在纯Python中:
def get_param_from_url(url, param_name):
return [i.split("=")[-1] for i in url.split("?", 1)[-1].split("&") if i.startswith(param_name + "=")][0]
参数= dict([part.split('=')) for part in get_parsed_url [4] .split (' & '))
这一点很简单。变量参数将包含所有参数的字典。