2016-10-07 12 views
0

私は下のforループ内で複数の抄録をダウンロードし、パイソンを通じてAPI(Scopusの)にアクセスしようとしています。そうすることにより、エラー処理へのアクセスAPI

for t in eid: 
    url = "http://api.elsevier.com/content/abstract/eid/"+str(t)+"?view=FULL" 
    # url = "http://api.elsevier.com/content/abstract/eid/2-s2.0-84934272190?view=FULL" 
    resp2 = requests.get(url, 
         headers={'Accept':'application/json', 
         'X-ELS-APIKey': MYAPIKEY}) 

    retrieval = resp2.json() 

    dep = retrieval['abstracts-retrieval-response']['item']['bibrecord']['head']['author-group'] 
    sub = retrieval['abstracts-retrieval-response']['subject-areas']['subject-area'] 
    iD = retrieval['abstracts-retrieval-response']['coredata']['intid'] 
    date = retrieval['abstracts-retrieval-response']['coredata']['prism:coverDate'] 

    department.append(dep) 
    subj.append(sub) 
    ident.append(iD) 
    dates.append(date) 

しかし、私は一緒に次のエラーを受信し続けます下の行(常にforループの異なる点にもあります)。 私はエラー処理がこれを回避する方法であると言われましたが、Pythonには新しく、これは何か分かりません。誰も助けることができますか?おかげ

編集:ここでは残念ながら、あなたがに記載されている「上記の例外」を含めていない

Traceback (most recent call last): 
    File "C:\Users\User\Anaconda3\lib\site-packages\requests\packages\urllib3\connection.py", line 142, in _new_conn 
    (self.host, self.port), self.timeout, **extra_kw) 
    File "C:\Users\User\Anaconda3\lib\site-packages\requests\packages\urllib3\util\connection.py", line 91, in create_connection 
    raise err 
    File "C:\Users\User\Anaconda3\lib\site-packages\requests\packages\urllib3\util\connection.py", line 81, in create_connection 
    sock.connect(sa) 
ConnectionAbortedError: [WinError 10053] An established connection was aborted by the software in your host machine 

During handling of the above exception, another exception occurred: 

Traceback (most recent call last): 
    File "C:\Users\User\Anaconda3\lib\site-packages\requests\packages\urllib3\connectionpool.py", line 578, in urlopen 
    chunked=chunked) 
    File "C:\Users\User\Anaconda3\lib\site-packages\requests\packages\urllib3\connectionpool.py", line 362, in _make_request 
    conn.request(method, url, **httplib_request_kw) 
    File "C:\Users\User\Anaconda3\lib\http\client.py", line 1106, in request 
    self._send_request(method, url, body, headers) 
    File "C:\Users\User\Anaconda3\lib\http\client.py", line 1151, in _send_request 
    self.endheaders(body) 
    File "C:\Users\User\Anaconda3\lib\http\client.py", line 1102, in endheaders 
    self._send_output(message_body) 
    File "C:\Users\User\Anaconda3\lib\http\client.py", line 934, in _send_output 
    self.send(msg) 
    File "C:\Users\User\Anaconda3\lib\http\client.py", line 877, in send 
    self.connect() 
    File "C:\Users\User\Anaconda3\lib\site-packages\requests\packages\urllib3\connection.py", line 167, in connect 
    conn = self._new_conn() 
    File "C:\Users\User\Anaconda3\lib\site-packages\requests\packages\urllib3\connection.py", line 151, in _new_conn 
    self, "Failed to establish a new connection: %s" % e) 
requests.packages.urllib3.exceptions.NewConnectionError: <requests.packages.urllib3.connection.HTTPConnection object at 0x000002058C7E1C18>: Failed to establish a new connection: [WinError 10053] An established connection was aborted by the software in your host machine 

During handling of the above exception, another exception occurred: 

Traceback (most recent call last): 
    File "C:\Users\User\Anaconda3\lib\site-packages\requests\adapters.py", line 403, in send 
    timeout=timeout 
    File "C:\Users\User\Anaconda3\lib\site-packages\requests\packages\urllib3\connectionpool.py", line 623, in urlopen 
    _stacktrace=sys.exc_info()[2]) 
    File "C:\Users\User\Anaconda3\lib\site-packages\requests\packages\urllib3\util\retry.py", line 281, in increment 
    raise MaxRetryError(_pool, url, error or ResponseError(cause)) 
requests.packages.urllib3.exceptions.MaxRetryError: HTTPConnectionPool(host='api.elsevier.com', port=80): Max retries exceeded with url: /content/abstract/eid/2-s2.0-84978766692?view=FULL (Caused by NewConnectionError('<requests.packages.urllib3.connection.HTTPConnection object at 0x000002058C7E1C18>: Failed to establish a new connection: [WinError 10053] An established connection was aborted by the software in your host machine',)) 

During handling of the above exception, another exception occurred: 

Traceback (most recent call last): 
    File "<stdin>", line 5, in <module> 
    File "C:\Users\User\Anaconda3\lib\site-packages\requests\api.py", line 71, in get 
    return request('get', url, params=params, **kwargs) 
    File "C:\Users\User\Anaconda3\lib\site-packages\requests\api.py", line 57, in request 
    return session.request(method=method, url=url, **kwargs) 
    File "C:\Users\User\Anaconda3\lib\site-packages\requests\sessions.py", line 475, in request 
    resp = self.send(prep, **send_kwargs) 
    File "C:\Users\User\Anaconda3\lib\site-packages\requests\sessions.py", line 585, in send 
    r = adapter.send(request, **kwargs) 
    File "C:\Users\User\Anaconda3\lib\site-packages\requests\adapters.py", line 467, in send 
    raise ConnectionError(e, request=request) 
requests.exceptions.ConnectionError: HTTPConnectionPool(host='api.elsevier.com', port=80): Max retries exceeded with url: /content/abstract/eid/2-s2.0-84978766692?view=FULL (Caused by NewConnectionError('<requests.packages.urllib3.connection.HTTPConnection object at 0x000002058C7E1C18>: Failed to establish a new connection: [WinError 10053] An established connection was aborted by the software in your host machine',)) 

答えて

0

(それが長いことを申し訳ありません)正しい情報のすべてを含める必要があり、全体のエラーメッセージですあなたの出力。

一般に、コードの実行中に例外などの例外的な状況(たとえばエラーなど)が発生した場合、その例外を捕捉して処理できます。例外は、何がうまくいかなかったかについての情報をボード上に持つオブジェクトです。例外処理は一般的に大きなテーマです。https://docs.python.org/3/tutorial/errors.html

例外を処理する例は、状況と例外を報告することです。これは、すでにあなたに何が悪かったのかで洞察力を与えることができる:

for t in eid: 
    try: 
     url = "http://api.elsevier.com/content/abstract/eid/"+str(t)+"?view=FULL" 
     # url = "http://api.elsevier.com/content/abstract/eid/2-s2.0-84934272190?view=FULL" 
     resp2 = requests.get(url, 
          headers={'Accept':'application/json', 
          'X-ELS-APIKey': MYAPIKEY}) 

     retrieval = resp2.json() 

     dep = retrieval['abstracts-retrieval-response']['item']['bibrecord']['head']['author-group'] 
     sub = retrieval['abstracts-retrieval-response']['subject-areas']['subject-area'] 
     iD = retrieval['abstracts-retrieval-response']['coredata']['intid'] 
     date = retrieval['abstracts-retrieval-response']['coredata']['prism:coverDate'] 

     department.append(dep) 
     subj.append(sub) 
     ident.append(iD) 
     dates.append(date) 
    except Exception as exception: 
     print (url) # 'print' will only work on a console 
     print (exception) 

[EDIT]

私はエラーメッセージを見て撮影した、それはあなたがに接続しようとしているサーバのようですが、接続を閉じました。理由は全く異なる場合がありますが、Why is host aborting connection?も参照してください。これは、いくつかの再試行での使用を構築するには、特定のURLの

[/ EDIT]

でのみすべての時間に発生かどうかを調べるために、上記のコードを試してみてください。

import time 

nrOfTries = 10 

for t in eid: 
    for count in range (nrOfTries): 
     try: 
      url = "http://api.elsevier.com/content/abstract/eid/"+str(t)+"?view=FULL" 
      # url = "http://api.elsevier.com/content/abstract/eid/2-s2.0-84934272190?view=FULL" 
      resp2 = requests.get(url, 
           headers={'Accept':'application/json', 
           'X-ELS-APIKey': MYAPIKEY}) 

      retrieval = resp2.json() 

      dep = retrieval['abstracts-retrieval-response']['item']['bibrecord']['head']['author-group'] 
      sub = retrieval['abstracts-retrieval-response']['subject-areas']['subject-area'] 
      iD = retrieval['abstracts-retrieval-response']['coredata']['intid'] 
      date = retrieval['abstracts-retrieval-response']['coredata']['prism:coverDate'] 

      department.append(dep) 
      subj.append(sub) 
      ident.append(iD) 
      dates.append(date) 

      break # Don't do the else 

     except Exception as exception: 
      print ('Problem accessing: {}' .format (url)) 
      print (exception) 
      time.sleep (2) # Seconds 
    else: # Done after for-loop exhausted, but not if 'break' was encountered 
     print ('Gave up accessing: {}' .format (url)) 

N.B.私はこれをテストしていないが、それは一般的な考えを伝えるべきである。 「スリープ」とは、サーバがその息を止めることを可能にすることです。

+0

申し訳ありません。エラーメッセージは非常に長く、そのスニペットを投稿しただけです。私は、有効な例外を含む全体のエラーを含めるためにEDITを作成します –

+0

私はエラーメッセージ全体を含めましたが、残念ですが、それは長いですが、私が信じる必要な情報を含める必要があります –

+0

例外があるようですランダムなURLで(理由はわかりませんが)、例外が発生すると、ループは通常どおり実行されます。そのホストのようなものは無作為に無作為にグリッチします。 –

関連する問題