6

そこで、Kenneth の優れたrequests モジュールを使用したいと思います。Freebase APIを使おうとしているときに、この問題に遭遇しました。

基本的に、彼らの API は次のようになります。

https://www.googleapis.com/freebase/v1/mqlread?query=...

クエリとして、彼らは JSON オブジェクトを期待します。これは、国とアルコールの割合を含むワインのリストを返すものです:

[{
  "country":       null,
  "name":          null,
  "percentage_alcohol": null,
  "percentage_alcohol>": 0,
  "type":          "/food/wine"
}]​

もちろん、URL に渡す前に、ここから完全にエスケープする必要があるため、実際のクエリは次のようになります。

 fullurl = 'https://www.googleapis.com/freebase/v1/mqlread?query=%5B%7B%22percentage_alcohol%3E%22%3A+0%2C+%22country%22%3A+null%2C+%22type%22%3A+%22%2Ffood%2Fwine%22%2C+%22name%22%3A+null%2C+%22percentage_alcohol%22%3A+null%7D%5D'

今、

r = requests.get(fullurl)
print r.status_code
>>> 400

サイトがクエリを解析できなかったと主張しているためです。

r2 = urllib2.urlopen(fullurl)
print r2.getcode()
>>> 200

こちらは問題ありません、ちゃんと返ってきます。興味深いことに、

# This is the url of our requests.get request
print urllib2.urlopen(r.url).getcode() 
>>> 200

なんで?モジュールの使い方が間違っていますか?それともバグrequestsですか?

4

1 に答える 1

7

わたしにはできる。これが私がしたことです:

>>> params = [{"country": None,
...            "name": None,
...            "percentage_alcohol": None,
...            "percentage_alcohol>": 0,
...            "type": "/food/wine"
...          }]
>>> import json
>>> params_json = json.dumps(params)

>>> import requests
>>> url = "https://www.googleapis.com/freebase/v1/mqlread?query=%s"
>>> r = requests.get(url % params_json)
>>> r.status_code
200

>>> content_json = json.loads(r.content)
>>> import pprint
>>> pprint.pprint(content_json)
{u'result': [{u'country': u'New Zealand',
              u'name': u'2003 Cloudy Bay Sauvignon Blanc',
              u'percentage_alcohol': 13.5,
              u'type': u'/food/wine'},
             {u'country': u'France',
              u'name': u'G.H. Mumm Cordon Rouge Brut',
              u'percentage_alcohol': 12.0,
              u'type': u'/food/wine'},
....

簡潔にするために残りを切り取りました。100件の結果があります。requests.__version__ == '0.10.6'

于 2012-05-08T17:35:04.050 に答える