質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
スクレイピング

スクレイピングとは、公開されているWebサイトからページ内の情報を抽出する技術です。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

pip

pipとは、Pythonを用いて書かれているパッケージソフトのインストールや管理を行うためのパッケージマネジメントシステムです。pipを使う主なメリットは、コマンドラインインターフェースにて容易にPythonパッケージソフトをインストール可能だという点です。

Q&A

解決済

2回答

3216閲覧

本の通りのコードなのに、スクレイピングできない

RinKawakami

総合スコア20

スクレイピング

スクレイピングとは、公開されているWebサイトからページ内の情報を抽出する技術です。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

pip

pipとは、Pythonを用いて書かれているパッケージソフトのインストールや管理を行うためのパッケージマネジメントシステムです。pipを使う主なメリットは、コマンドラインインターフェースにて容易にPythonパッケージソフトをインストール可能だという点です。

0グッド

1クリップ

投稿2019/01/21 05:49

編集2019/01/21 05:52

前提・実現したいこと

「独習Python入門」をみながら練習しています。
Webスクレイピングのページで、教科書通りのコードを入力しているのですが、エラーが表示されます。

発生している問題・エラーメッセージ

長いですが・・・

Traceback (most recent call last): File "/Library/Frameworks/Python.framework/Versions/3.7/lib/python3.7/urllib/request.py", line 1317, in do_open encode_chunked=req.has_header('Transfer-encoding')) File "/Library/Frameworks/Python.framework/Versions/3.7/lib/python3.7/http/client.py", line 1229, in request self._send_request(method, url, body, headers, encode_chunked) File "/Library/Frameworks/Python.framework/Versions/3.7/lib/python3.7/http/client.py", line 1275, in _send_request self.endheaders(body, encode_chunked=encode_chunked) File "/Library/Frameworks/Python.framework/Versions/3.7/lib/python3.7/http/client.py", line 1224, in endheaders self._send_output(message_body, encode_chunked=encode_chunked) File "/Library/Frameworks/Python.framework/Versions/3.7/lib/python3.7/http/client.py", line 1016, in _send_output self.send(msg) File "/Library/Frameworks/Python.framework/Versions/3.7/lib/python3.7/http/client.py", line 956, in send self.connect() File "/Library/Frameworks/Python.framework/Versions/3.7/lib/python3.7/http/client.py", line 1392, in connect server_hostname=server_hostname) File "/Library/Frameworks/Python.framework/Versions/3.7/lib/python3.7/ssl.py", line 412, in wrap_socket session=session File "/Library/Frameworks/Python.framework/Versions/3.7/lib/python3.7/ssl.py", line 853, in _create self.do_handshake() File "/Library/Frameworks/Python.framework/Versions/3.7/lib/python3.7/ssl.py", line 1117, in do_handshake self._sslobj.do_handshake() ssl.SSLCertVerificationError: [SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed: unable to get local issuer certificate (_ssl.c:1051) During handling of the above exception, another exception occurred: Traceback (most recent call last): File "do_scraping.py", line 5, in <module> req = urllib.request.urlopen('http://quality-start.in/company/') File "/Library/Frameworks/Python.framework/Versions/3.7/lib/python3.7/urllib/request.py", line 222, in urlopen return opener.open(url, data, timeout) File "/Library/Frameworks/Python.framework/Versions/3.7/lib/python3.7/urllib/request.py", line 531, in open response = meth(req, response) File "/Library/Frameworks/Python.framework/Versions/3.7/lib/python3.7/urllib/request.py", line 641, in http_response 'http', request, response, code, msg, hdrs) File "/Library/Frameworks/Python.framework/Versions/3.7/lib/python3.7/urllib/request.py", line 563, in error result = self._call_chain(*args) File "/Library/Frameworks/Python.framework/Versions/3.7/lib/python3.7/urllib/request.py", line 503, in _call_chain result = func(*args) File "/Library/Frameworks/Python.framework/Versions/3.7/lib/python3.7/urllib/request.py", line 755, in http_error_302 return self.parent.open(new, timeout=req.timeout) File "/Library/Frameworks/Python.framework/Versions/3.7/lib/python3.7/urllib/request.py", line 525, in open response = self._open(req, data) File "/Library/Frameworks/Python.framework/Versions/3.7/lib/python3.7/urllib/request.py", line 543, in _open '_open', req) File "/Library/Frameworks/Python.framework/Versions/3.7/lib/python3.7/urllib/request.py", line 503, in _call_chain result = func(*args) File "/Library/Frameworks/Python.framework/Versions/3.7/lib/python3.7/urllib/request.py", line 1360, in https_open context=self._context, check_hostname=self._check_hostname) File "/Library/Frameworks/Python.framework/Versions/3.7/lib/python3.7/urllib/request.py", line 1319, in do_open raise URLError(err) urllib.error.URLError: <urlopen error [SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed: unable to get local issuer certificate (_ssl.c:1051)>

該当のソースコード

Python3

1#encoding: utf-8 2 3import urllib.request 4from bs4 import BeautifulSoup 5req = urllib.request.urlopen('http://quality-start.in/company/') 6soup = BeautifulSoup(req, "html.parser") 7print(soup.find('h1').text) 8

試したこと

①何度もコードを見直しましたが、まさしく教科書通りでした。
(エラーメッセージ的に、単なる誤入力ではない?)

②[SSL: CERTIFICATE_VERIFY_FAILED] というエラーメッセージで検索して、
https://qiita.com/orangain/items/0a641d980019fd7e0c52
を参考に、certifiモジュールをインストールしました。

しかし、エラーのままです・・・

補足情報(FW/ツールのバージョンなど)

MacOS
pip9.0.1

質問者がプログラミング初心者のため、基本的なミスかもしれませんが、お助けください!

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

can110

2019/01/21 06:03

参考ページはpythonバージョン3.6用に書かれているようです。 「試したこと」で、実際におこなった手順を記載ください。
RinKawakami

2019/01/21 06:13

ありがとうございます! ご指摘の通り、「Python3.6」についてcerifiモジュールをダウンロードしていたため、 /Applications/Python\ 3.7/Install\ Certificates.command というように、 「3.6」→「3.7」とすることで、解決しました! 解決策の実行には、バージョンを確認する必要があるんですね…!
guest

回答2

0

参考ページはpythonバージョン3.6用に書かれているようです。
当方mac環境はわからず動作未検証ですが3.7環境だと
/Applications/Python\ 3.7/Install\ Certificates.commandと実行すべきかと思います。

投稿2019/01/21 06:06

can110

総合スコア38262

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

ベストアンサー

Python

1req = urllib.request.urlopen('https://quality-start.in/company/')

http=>httpsにしてみてください

投稿2019/01/21 05:52

yamato_user

総合スコア2321

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

RinKawakami

2019/01/21 05:59

ありがとうございます。 試してみましたが、ダメでした…。
RinKawakami

2019/01/21 06:11

ありがとうございます! 自分がダウンロードしていたcertifiモジュールは、別の方のご指摘の通り、Python3.6について行なっていました。 同様の手続きを、「3.7」に書き換えて行なったところ、できるようになりました! 素早いご回答ありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問