以前,我对PatentsView的呼叫是有效的。具体地说,我记得运行下面的代码块(来自另一个stackoverflow post)并得到一个无错误的输出。现在我得到了一个400错误。导致这种情况的原因可能是什么?也许是请求库?我通过在浏览器中粘贴以下结果来获得结果,但不能使用requests库进行复制(即使我减少了查询参数以简化调用)。参数f和o不是必需的,"_and“标准也不是必需的。您只需在url和问号后面传递q={"_gte":{"patent_date":"2007-01-04"}}即可获得有效结果。这很奇怪。
from urllib.request import Request, urlopen
import json
url = "http://www.patentsview.org/api/patents/query"
author = "Jobs"
title = "computer"
data = {
'q':{
"_and":[
{"inventor_last_name":author},
{"_text_any":{"patent_title":title}}
]
},
'o':{"matched_subentities_only": "true"}
}
resp = urlopen(Request(url, json.dumps(data).encode()))
data = resp.read()
#data = json.loads(data)发布于 2020-06-13 14:35:21
我认为你应该只json.dumps data的值。
您可以按如下方式对其进行解析:
from urllib.request import Request, urlopen
from urllib.parse import urlencode
import json
url = "http://www.patentsview.org/api/patents/query"
author = "Jobs"
title = "computer"
data = {
'q':{
"_and":[
{"inventor_last_name":author},
{"_text_any":{"patent_title":title}}
]
},
'o':{"matched_subentities_only": "true"}
}
data = dict(map(lambda x: (x[0], json.dumps(x[1])), data.items() ))
resp = urlopen(Request(url +'?' + urlencode(data)))
print(resp.read())这应该可以解决这个问题
发布于 2020-06-13 14:19:04
这似乎起作用了:
import json
from urllib.request import Request, urlopen
import urllib
data = {
'q':{
"_and":[
{"inventor_last_name":author},
{"_text_any":{"patent_title":title}}
]
},
'o':{"matched_subentities_only": "true"}
}
base_url = "http://www.patentsview.org/api/patents/query"
url = base_url + "?q=" + urllib.parse.quote(json.dumps(data["q"]))
res = urlopen(url)https://stackoverflow.com/questions/62356089
复制相似问题