0

私はこの1日ほどグループと協力して、ユーザーのクラスター係数(友達の相互接続性の尺度)を計算するFacebookアプリを作成しました。
これを実現するには、相互の友達の数を取得する必要があります。それぞれの友達と一緒にいるユーザー。残念ながら、urllib2.HTTPErrorが発生し続け、何が起こっているのか理解できません。https://gentle-stream-3754.herokuapp.com/でアプリ(およびエラーメッセージ+トレースバック)にアクセスできます。

特に168行目はトレースバックの一部でした。以下のコードはコンテキストなしでは役に立たない可能性が高いことを知っているので、アプリへのリンクを含めました。

ユーザー権限に問題があるのでしょうか?ランタイム?

どんな助けでもいただければ幸いです!前もって感謝します!

編集:access_tokenはNoneTypeオブジェクトのように見えますが、その理由は完全にはわかりません。これがurllib2.HTTPErrorの原因である可能性がありますか?

164 def clustering_coefficient():
165 
166     access_token = get_token()
167     g = Graph(access_token)
168     requests = [{'method': 'GET', 'relative_url': 'me/mutualfriends/%s' % x['id']} for x in g.me.friends()['data']]
169     k_v = len(requests)
170     if k_v < 2:
171         return 0.0
172 
173     n_v = 0
174     REQS_PER_POST = 50 
175     for i in range((k_v // REQS_PER_POST)+1):
176         result = g.post(batch=json.dumps(requests[i*REQS_PER_POST:(i+1)*REQS_PER_POST]))
177         for r in result:
178             body = json.loads(r['body'])
179             n_v += len(body['data'])
180 
181     return 1.0 * n_v / k_v/ (k_v-1)

例外:HTTPError:HTTPエラー400:不正なリクエスト

トレースバック:

Traceback (most recent call last)
File "/app/lib/python2.7/site-packages/flask/app.py", line 1306, in __call__
return self.wsgi_app(environ, start_response)
File "/app/lib/python2.7/site-packages/flask/app.py", line 1294, in wsgi_app
response = self.make_response(self.handle_exception(e))
File "/app/lib/python2.7/site-packages/flask/app.py", line 1292, in wsgi_app
response = self.full_dispatch_request()
File "/app/lib/python2.7/site-packages/flask/app.py", line 1062, in full_dispatch_request
rv = self.handle_user_exception(e)
File "/app/lib/python2.7/site-packages/flask/app.py", line 1060, in full_dispatch_request
rv = self.dispatch_request()
File "/app/lib/python2.7/site-packages/flask/app.py", line 1047, in dispatch_request
return self.view_functions[rule.endpoint](**req.view_args)
File "/app/exampleapp.py", line 168, in clustering_coefficient
requests = [{'method': 'GET', 'relative_url': 'me/mutualfriends/%s' % x['id']} for x in g.me.friends()['data']]
File "/app/lib/python2.7/site-packages/facegraph/graph.py", line 157, in __call__
data = json.loads(self.fetch(self.url | params))
File "/app/lib/python2.7/site-packages/facegraph/graph.py", line 203, in fetch
conn = urllib2.urlopen(url, data=data)
File "/usr/local/lib/python2.7/urllib2.py", line 126, in urlopen
return _opener.open(url, data, timeout)
File "/usr/local/lib/python2.7/urllib2.py", line 400, in open
response = meth(req, response)
File "/usr/local/lib/python2.7/urllib2.py", line 513, in http_response
'http', request, response, code, msg, hdrs)
File "/usr/local/lib/python2.7/urllib2.py", line 438, in error
return self._call_chain(*args)
File "/usr/local/lib/python2.7/urllib2.py", line 372, in _call_chain
result = func(*args)
File "/usr/local/lib/python2.7/urllib2.py", line 521, in http_error_default
raise HTTPError(req.get_full_url(), code, msg, hdrs, fp)
4

1 に答える 1

1

これはフェイスグラフライブラリの問題のようです。400ステータスコードを受信するリクエストを送信しています。最新バージョンを使用していますか?Facebook APIの何かが変更され、facegraphに問題が発生する可能性はありますか?

于 2012-07-12T17:52:25.297 に答える