Scikit-learn: fetch_california_housing()URLError:<urlopen error="" certificate_verify_failed="" certificate="" verify="" failed=""/>

作成日 2017年11月25日  ·  12コメント  ·  ソース: scikit-learn/scikit-learn

説明

fetch_california_housing()を使用してサンプルデータセットをダウンロードできません。 証明書の有効期限が切れているようですか?

再現する手順/コード

print( 'scikit-learnのバージョンは{}。'。format(sklearn .__ version__))
sklearn.datasetsからimportfetch_california_housing
住宅= fetch_california_housing()

実績

Downloading Cal. housing from https://ndownloader.figshare.com/files/5976036 to /Users/test/scikit_learn_data
The scikit-learn version is 0.19.1.
---------------------------------------------------------------------------
SSLError                                  Traceback (most recent call last)
/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/urllib/request.py in do_open(self, http_class, req, **http_conn_args)
   1317                 h.request(req.get_method(), req.selector, req.data, headers,
-> 1318                           encode_chunked=req.has_header('Transfer-encoding'))
   1319             except OSError as err: # timeout error

/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/http/client.py in request(self, method, url, body, headers, encode_chunked)
   1238         """Send a complete request to the server."""
-> 1239         self._send_request(method, url, body, headers, encode_chunked)
   1240 

/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/http/client.py in _send_request(self, method, url, body, headers, encode_chunked)
   1284             body = _encode(body, 'body')
-> 1285         self.endheaders(body, encode_chunked=encode_chunked)
   1286 

/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/http/client.py in endheaders(self, message_body, encode_chunked)
   1233             raise CannotSendHeader()
-> 1234         self._send_output(message_body, encode_chunked=encode_chunked)
   1235 

/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/http/client.py in _send_output(self, message_body, encode_chunked)
   1025         del self._buffer[:]
-> 1026         self.send(msg)
   1027 

/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/http/client.py in send(self, data)
    963             if self.auto_open:
--> 964                 self.connect()
    965             else:

/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/http/client.py in connect(self)
   1399             self.sock = self._context.wrap_socket(self.sock,
-> 1400                                                   server_hostname=server_hostname)
   1401             if not self._context.check_hostname and self._check_hostname:

/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/ssl.py in wrap_socket(self, sock, server_side, do_handshake_on_connect, suppress_ragged_eofs, server_hostname, session)
    400                          server_hostname=server_hostname,
--> 401                          _context=self, _session=session)
    402 

/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/ssl.py in __init__(self, sock, keyfile, certfile, server_side, cert_reqs, ssl_version, ca_certs, do_handshake_on_connect, family, type, proto, fileno, suppress_ragged_eofs, npn_protocols, ciphers, server_hostname, _context, _session)
    807                         raise ValueError("do_handshake_on_connect should not be specified for non-blocking sockets")
--> 808                     self.do_handshake()
    809 

/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/ssl.py in do_handshake(self, block)
   1060                 self.settimeout(None)
-> 1061             self._sslobj.do_handshake()
   1062         finally:

/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/ssl.py in do_handshake(self)
    682         """Start the SSL/TLS handshake."""
--> 683         self._sslobj.do_handshake()
    684         if self.context.check_hostname:

SSLError: [SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed (_ssl.c:749)

During handling of the above exception, another exception occurred:

URLError                                  Traceback (most recent call last)
<ipython-input-18-dc07bc139b51> in <module>()
      1 print('The scikit-learn version is {}.'.format(sklearn.__version__))
      2 from sklearn.datasets import fetch_california_housing
----> 3 housing = fetch_california_housing()

/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site-packages/sklearn/datasets/california_housing.py in fetch_california_housing(data_home, download_if_missing)
     99             ARCHIVE.url, data_home))
    100 
--> 101         archive_path = _fetch_remote(ARCHIVE, dirname=data_home)
    102 
    103         with tarfile.open(mode="r:gz", name=archive_path) as f:

/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site-packages/sklearn/datasets/base.py in _fetch_remote(remote, dirname)
    872     file_path = (remote.filename if dirname is None
    873                  else join(dirname, remote.filename))
--> 874     urlretrieve(remote.url, file_path)
    875     checksum = _sha256(file_path)
    876     if remote.checksum != checksum:

/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/urllib/request.py in urlretrieve(url, filename, reporthook, data)
    246     url_type, path = splittype(url)
    247 
--> 248     with contextlib.closing(urlopen(url, data)) as fp:
    249         headers = fp.info()
    250 

/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/urllib/request.py in urlopen(url, data, timeout, cafile, capath, cadefault, context)
    221     else:
    222         opener = _opener
--> 223     return opener.open(url, data, timeout)
    224 
    225 def install_opener(opener):

/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/urllib/request.py in open(self, fullurl, data, timeout)
    524             req = meth(req)
    525 
--> 526         response = self._open(req, data)
    527 
    528         # post-process response

/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/urllib/request.py in _open(self, req, data)
    542         protocol = req.type
    543         result = self._call_chain(self.handle_open, protocol, protocol +
--> 544                                   '_open', req)
    545         if result:
    546             return result

/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/urllib/request.py in _call_chain(self, chain, kind, meth_name, *args)
    502         for handler in handlers:
    503             func = getattr(handler, meth_name)
--> 504             result = func(*args)
    505             if result is not None:
    506                 return result

/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/urllib/request.py in https_open(self, req)
   1359         def https_open(self, req):
   1360             return self.do_open(http.client.HTTPSConnection, req,
-> 1361                 context=self._context, check_hostname=self._check_hostname)
   1362 
   1363         https_request = AbstractHTTPHandler.do_request_

/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/urllib/request.py in do_open(self, http_class, req, **http_conn_args)
   1318                           encode_chunked=req.has_header('Transfer-encoding'))
   1319             except OSError as err: # timeout error
-> 1320                 raise URLError(err)
   1321             r = h.getresponse()
   1322         except:

URLError: <urlopen error [SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed (_ssl.c:749)>

最も参考になるコメント

うーん!

問題を見つけました。 Mac上のPython3.6には、インストール後の手順が必要です

$ less /Applications/Python\ 3.6/ReadMe.rtf

「以前のリリースとは異なり、廃止されたApple提供のOpenSSLライブラリは使用されなくなりました。これは、キーチェーンアクセスアプリケーションとセキュリティコマンドラインユーティリティによって管理されるシステムおよびユーザーキーチェーンの信頼証明書がデフォルトとして使用されなくなったことも意味します。」

解決策は

$ sudo /Applications/Python\ 3.6/Install\ Certificates.command

全てのコメント12件

さて、それが非常に一時的なものであることを願っています...それはまだ問題ですか?

こんにちはJnothman

私は金曜日にこの問題に最初に気づきました。 まだ同じエラーが発生します

URLError:

敬具

アンディ

私はその問題を抱えていません。 時計を設定していませんか?
間違っているか何か?

こんにちはJnothman

私はMacBookProを使用しています。 コンピューターに表示されている時刻が正しいようです。 コードをもう一度実行したところ、同じエラーが発生しました

時計が正しく設定されているかどうかを確認する方法はありますか?

アンディ

言及するのを忘れました。 私はコードを見ていませんが、ローカルディスクにデータセットをすでにダウンロードしている場合は、実際にフェッチされることはないので、おそらくそれがあなたのために機能する理由です

奇妙なことに、私は確かに再現できません。また、cal_housingデータを~/scikit_learn_dataから削除したので、これはscikit-learnでは問題にならないようです。 これを閉じます。問題を解決できた場合に備えて、 @ AEDWIPから詳細情報を提供してください。

同様の問題が発生します-MacBook Pro、HighSierra。

このSSL証明書の専門家ではありませんが、前述のように、これはscikit-learnに関連しているとは思いません。

このスニペットでも同じエラーが発生しますか?

from six.moves.urllib.request import urlretrieve
urlretrieve('https://ndownloader.figshare.com/files/5976036')

うーん!

問題を見つけました。 Mac上のPython3.6には、インストール後の手順が必要です

$ less /Applications/Python\ 3.6/ReadMe.rtf

「以前のリリースとは異なり、廃止されたApple提供のOpenSSLライブラリは使用されなくなりました。これは、キーチェーンアクセスアプリケーションとセキュリティコマンドラインユーティリティによって管理されるシステムおよびユーザーキーチェーンの信頼証明書がデフォルトとして使用されなくなったことも意味します。」

解決策は

$ sudo /Applications/Python\ 3.6/Install\ Certificates.command

Ubuntu16.04のPython3.6でも同じ問題が発生します

ここで解決策が見つかりました:http: //blog.pengyifan.com/how-to-fix-python-ssl-certificate_verify_failed/

import os, ssl
if (not os.environ.get('PYTHONHTTPSVERIFY', '') and
    getattr(ssl, '_create_unverified_context', None)): 
    ssl._create_default_https_context = ssl._create_unverified_context

おかげで、nfrikからのコードは機能しました

このページは役に立ちましたか?
0 / 5 - 0 評価