我一直在开发一个小型宠物项目,我使用 http.client 与 omdbapi 进行通信(如果术语不好,请随时纠正我)。 。从这里我使用以下代码访问网站上的数据:
import http.client, json
__connection = http.client.HTTPConnection("www.omdbapi.com")
def getDetailsFromTitle(title):
__connection.request("GET", "/?t=" + title)
return __processRequest()
def getDetailsFromID(id):
__connection.request("GET", "/?i=" + id)
return __processRequest()
def __processRequest():
try:
response = __connection.getresponse()
data = response.read()
data = data.decode("utf-8")
return json.loads(data)
except: return None
这对于我的前几次试验效果很好,就像如果我查找说“Eureka”或“Superbad”,我就能够正确地取回所有数据;然而,当我输入“Bad Kids Go To Hell”时,我在 __processRequest 中的尝试就被破坏了,并且没有返回任何内容。 我设法从请求中获取的数据是:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN""http://www.w3.org/TR/html4/strict.dtd">
<HTML><HEAD><TITLE>Bad Request</TITLE>
<META HTTP-EQUIV="Content-Type" Content="text/html; charset=us-ascii"></HEAD>
<BODY><h2>Bad Request</h2>
<hr><p>HTTP Error 400. The request is badly formed.</p>
</BODY></HTML>
这显然破坏了 json.loads(data),因为数据不是预期的,但我不太确定为什么会收到此错误。我访问该网站并输入“Bad Kids Go To Hell”,一切正常。
如果您需要更多帮助,请告诉我, 谢谢。
最佳答案
要创建网址的参数列表,您应该使用[urlencode()][1]
。在这种情况下,字符串中的空格可能会导致问题,应将它们转换为“+”字符。
__connection.request("GET", "/"+(urlencode({'t': title})
关于http - Python 3,http.client HTTP 错误 400,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13656381/