我有以下网址:
https://ide50-username.cs50.io/search?q=New%20Haven+CT
当我使用Flask方法时:
q = request.args.get("q")
它只是返回字符串“ New Haven CT”,实际上将%20
和+
都转换为空格
我想分别从URL中将参数“ New Haven”和“ CT”作为列表中的两个项目读取。我该怎么办?
答案 0 :(得分:0)
如果您真的想用+
分隔参数。您可以自己解析URL。(警告:它不如urllib.parse.parse_qs
安全。)
urllib.parse.unquote
函数不会将+
解析为空格,urllib.parse.unquote_plus
会解析。 See the docs。
一个例子:
from urllib.parse import unquote
def parse_query_string(query_string):
pairs = [s2 for s1 in query_string.split('&') for s2 in s1.split(';')]
parse_result = {}
for pair in pairs:
name_value = pair.split('=', 1)
if len(name_value) != 2:
continue
if len(name_value[1]):
name = unquote(name_value[0])
_value = unquote(name_value[1])
# separate value with +
values = _value.split('+')
if name in parse_result:
parse_result[name].extend(values)
else:
parse_result[name] = values
return parse_result
@app.route('/search')
def search():
# Get raw query_string
raw_query_string = request.query_string.decode()
queries = parse_query_string(raw_query_string)
q = queries.get('q')
return ''
有一种简单的方法,如果您可以将网址设为q=New%20Haven&q=CT
,那么Flask可以将q
解析为多个值。
print(request.args)
# output: ImmutableMultiDict([('q', 'New Haven'), ('q', 'CT')])
或使用urllib.parse.parse_qs
自己解析。
raw_query_string = request.query_string.decode()
print(parse_qs(raw_query_string))
# output: {'q': ['New Haven', 'CT']}