在构建URL时,requests
库会自动处理参数的编码,包括将空格转换为加号(+)。如果你直接在URL中使用加号,requests
会将其视为空格,因此在发送请求之前,它会将加号替换为URL编码的空格。
为了避免这种情况,你应该在构建参数时使用字典,让requests
库来处理编码。下面是一个例子:
import requests
url = "https:/xxx/xxx/xxx"
params = {
'sub': 'list',
'search_field': 'null',
'begin': '3165',
'count': '5',
'query': '',
'fakeid': 'MzA4NDY4MzkyNA==',
'type': '101_1',
'free_publish_type': '1',
'sub_action': 'list_ex',
'token': '1470923186',
'lang': 'zh_CN',
'f': 'json',
'ajax': '1'
}
response = requests.get(url, params=params)
print(response.url) # 打印出实际发送的URL
在这个例子中,params
字典中的空格会被requests
库自动编码为加号。这样,当你打印出response.url
时,你会看到正确的URL,其中空格已经被编码为加号。
如果你需要在URL中直接包含加号而不是空格,你可以使用urllib.parse.quote_plus
来手动编码参数:
from urllib.parse import quote_plus
params = {
'sub': 'list',
'search_field': 'null',
'begin': '3165',
'count': '5',
'query': '',
'fakeid': 'MzA4NDY4MzkyNA==',
'type': '101_1',
'free_publish_type': '1',
'sub_action': 'list_ex',
'token': '1470923186',
'lang': 'zh_CN',
'f': 'json',
'ajax': '1'
}
# 手动编码参数
encoded_params = '&'.join(f"{quote_plus(k)}={quote_plus(str(v))}" for k, v in params.items())
# 构建完整的URL
full_url = f"{url}?{encoded_params}"
response = requests.get(full_url)
print(response.url) # 打印出实际发送的URL
在这个例子中,我们使用quote_plus
来手动编码参数,这样加号会被保留在URL中。
最后我的建议是直接把空格去了就好了,我是误输入了