★悩み★
・PythonからGoogle検索ってできるんだろうか。
・Google検索結果からページタイトルとURLを抽出できないかな。
・BeautifulSoupを利用したGoogle検索の方法が分からないな。
こういった「悩み」に答えます。
★本記事の内容★
BeautifulSoupを用いてPythonでGoogle検索する方法をご紹介
これからご紹介する「BeautifulSoupを用いてPythonでGoogle検索する方法」を実践したことで、筆者は15分以内でPythonからGoogle検索できました。
記事の前半では「BeautifulSoupをインストールする方法」を解説しつつ、記事の後半では「BeautifulSoupを用いてPythonでGoogle検索する方法」をご紹介します。
この記事を読み終えることで、「BeautifulSoupを用いてPythonでGoogle検索する方法」を把握した状態になります。
ちなみに、「Webブラウザ経由でGoogle検索する方法」を知りたい方には、以下の記事がオススメです。
ちなみに、PythonでYAHOO!JAPAN検索をする方法を知りたい方は、以下をご覧ください。
BeautifulSoupを用いてPythonでGoogle検索する方法
BeautifulSoupを用いてPythonでGoogle検索する方法をご紹介します。
★BeautifulSoupを用いてPythonでGoogle検索するまでの流れ★
ステップ1:Pythonのインストール
ステップ2:BeautifulSoupのインストール
ステップ3:PythonでGoogle検索するプログラムの実装
ステップ4:実装したPythonでGoogle検索するプログラムの動作確認
上記の流れで「BeautifulSoupを用いてPythonでGoogle検索する方法」をご紹介していきます。
上記の各ステップは、以下の環境で動作確認済みです。
動作確認済み環境:CentOS Linux release 7.8.2003 (Core)
以降で、各ステップに関してご紹介します。
ステップ1:Pythonのインストール
以下の記事を参考にし、お使いのパソコンやサーバーにPythonをインストールしましょう。
>> 【ubuntu向け】pyenvでPythonをインストールする手順【簡単】
>> 【コピペOK】pyenvでPythonをインストールする手順【Linux用】
>> 【最短5分】PyAutoGUIをWindowsにインストールする手順の「手順1:Pythonのインストール」を参照
>> 【環境構築】インストーラーでMacOSにPythonをインストール
既にPythonをインストールされている方は、本ステップを省略してください。
以上で、「ステップ1:Pythonのインストール」は完了です。
ステップ2:BeautifulSoupのインストール【Google検索に必須】
PythonでGoogle検索するために必要な「BeautifulSoup」などのライブラリーをインストールしましょう。
端末またはコマンドプロンプトを起動し、以下のコマンドを順に実行します。
$ sudo pip3 install requests
$ sudo pip3 install bs4
$ sudo pip3 install lxml
上記コマンドにより、PythonでGoogle検索するために必要なライブラリーのインストールができました。
requests:Google検索に利用
bs4:BeautifulSoupライブラリーで検索結果のスクレイピングに利用
lxml:xPathに利用(簡単に検索結果からタイトルとURLを抽出できます。)
以上で、「ステップ2:BeautifulSoupのインストール」は完了です。
ステップ3:PythonでGoogle検索するプログラムの実装
PythonでGoogle検索するプログラムの実装に関してご紹介します。
以下のプログラムをgoogle-search-beautifulsoup.pyというファイル名で保存しましょう。
import requests
from bs4 import BeautifulSoup
# Googleで検索したキーワードを設定
keyword = "Python Google検索"
# Google検索のURLを作成 (num=10とすることでGoogle検索の上位10件を取得可能)
url = 'https://www.google.co.jp/search?num=10' + '&q=' + keyword
# 検索するためのメタ情報を作成
user_agent = "Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:65.0) Gecko/20100101 Firefox/65.0"
headers = {"User-Agent": user_agent, 'Accept':'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8'}
# Google検索を実施
source=requests.get(url, headers=headers).text
# Google検索の結果からタイトルとURLを抽出
soup = BeautifulSoup(source, 'lxml')
search_div = soup.find_all(class_='rc')
# 抽出したタイトルとURLを表示
for result in search_div: # loop result list
title = result.h3.string
page_url = result.a.get('href')
print(title)
print(page_url)
print("---------")
以上で、「ステップ3:PythonでGoogle検索するプログラムの実装」は完了です。
ステップ4:実装したPythonでGoogle検索するプログラムの動作確認
実装したPythonでGoogle検索するプログラムの動作確認に関してご紹介します。
以下のコマンドを実行し、PythonでGoogle検索するプログラムの動作を確認しましょう。
$ python3 google-search-beautifulsoup.py
PythonでGoogle検索順位スクレイピング/BeautifulSoupの ...
https://101010.fun/programming/python-beautifulsoup-googlerank.html
---------
【初心者向け】Pythonでスクレイピングする環境を作る⑤ ...
![](https://assets.st-note.com/production/uploads/images/19102146/rectangle_large_type_2_827e4c4a0e7208d9ec3c3cf0c08cc739.jpeg?fit=bounds&quality=85&width=1280)
【初心者向け】Pythonでスクレイピングする環境を作る⑤ Google検索をしてみる|NaruhikoNaruhiko です。 サイトのデータの取得を簡単ですが説明しました。 Python の詳しい内容は専門書などにおまかせしますが、 前回までの方法をそのまま行えばスクレイピングが出来るようになっていると思います。 今回は、Google検索の結果を元にサイトのデータを取得してみます。 前回作成したコードはこれです...
---------
【Pythonスクレイピング】Google検索結果TOP3を自動抽出 ...
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fcdn.qiita.com%2Fassets%2Fpublic%2Farticle-ogp-background-9f5428127621718a910c8b63951390ad.png?ixlib=rb-4.0.0&w=1200&mark64=aHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTkxNiZoPTMzNiZ0eHQ9JUUzJTgwJTkwUHl0aG9uJUUzJTgyJUI5JUUzJTgyJUFGJUUzJTgzJUFDJUUzJTgyJUE0JUUzJTgzJTk0JUUzJTgzJUIzJUUzJTgyJUIwJUUzJTgwJTkxR29vZ2xlJUU2JUE0JTlDJUU3JUI0JUEyJUU3JUI1JTkwJUU2JTlFJTlDVE9QMyVFMyU4MiU5MiVFOCU4NyVBQSVFNSU4QiU5NSVFNiU4QSVCRCVFNSU4NyVCQSVFMyU4MSU5OSVFMyU4MiU4QiZ0eHQtY29sb3I9JTIzMjEyMTIxJnR4dC1mb250PUhpcmFnaW5vJTIwU2FucyUyMFc2JnR4dC1zaXplPTU2JnR4dC1jbGlwPWVsbGlwc2lzJnR4dC1hbGlnbj1sZWZ0JTJDdG9wJnM9Yjg2MDI0NjA1YTgwOTQ5ZGYyMzQ4MzM4ZGZmYmQ3MzY&mark-x=142&mark-y=112&blend64=aHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTYxNiZ0eHQ9JTQwU2hpbkthbm8mdHh0LWNvbG9yPSUyMzIxMjEyMSZ0eHQtZm9udD1IaXJhZ2lubyUyMFNhbnMlMjBXNiZ0eHQtc2l6ZT0zNiZ0eHQtYWxpZ249bGVmdCUyQ3RvcCZzPTY2ZmI4NWJlZmQ0NTAxZjRjNGE2MDEyM2ZmNzY0NTU4&blend-x=142&blend-y=491&blend-mode=normal&s=0dfef8c553d0e332793203027b3fab3c)
【Pythonスクレイピング】Google検索結果TOP3を自動抽出する - Qiitaプログラミング歴45日の素人が書いています。ご注意ください。#注意スクレイピングは利用方法によってはスクレイピング先のサーバに異常な負荷がかかります。場合によってはグレー、違法となる可能性が…
---------
【Python】Google検索結果上位サイトのタイトルの特徴を ...
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fcdn.qiita.com%2Fassets%2Fpublic%2Farticle-ogp-background-9f5428127621718a910c8b63951390ad.png?ixlib=rb-4.0.0&w=1200&mark64=aHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTkxNiZoPTMzNiZ0eHQ9JUUzJTgwJTkwUHl0aG9uJUUzJTgwJTkxR29vZ2xlJUU2JUE0JTlDJUU3JUI0JUEyJUU3JUI1JTkwJUU2JTlFJTlDJUU0JUI4JThBJUU0JUJEJThEJUUzJTgyJUI1JUUzJTgyJUE0JUUzJTgzJTg4JUUzJTgxJUFFJUUzJTgyJUJGJUUzJTgyJUE0JUUzJTgzJTg4JUUzJTgzJUFCJUUzJTgxJUFFJUU3JTg5JUI5JUU1JUJFJUI0JUUzJTgyJTkyJUU2JThFJUEyJUUzJTgxJUEzJUUzJTgxJUE2JUUzJTgxJUJGJUUzJTgyJThCJnR4dC1jb2xvcj0lMjMyMTIxMjEmdHh0LWZvbnQ9SGlyYWdpbm8lMjBTYW5zJTIwVzYmdHh0LXNpemU9NTYmdHh0LWNsaXA9ZWxsaXBzaXMmdHh0LWFsaWduPWxlZnQlMkN0b3Amcz00ZTYyZTY1YTU2YTRiMWZkMjQzNmMwNjk0NGNkNmJlZA&mark-x=142&mark-y=112&blend64=aHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTYxNiZ0eHQ9JTQwcHl0b21vJnR4dC1jb2xvcj0lMjMyMTIxMjEmdHh0LWZvbnQ9SGlyYWdpbm8lMjBTYW5zJTIwVzYmdHh0LXNpemU9MzYmdHh0LWFsaWduPWxlZnQlMkN0b3Amcz0yNTczNGE4MDFmZjJjM2YyMjRmMGE3YTZjMjczZDRhOA&blend-x=142&blend-y=491&blend-mode=normal&s=2c2afc578155096d4f9ff5fab01ceab3)
【Python】Google検索結果上位サイトのタイトルの特徴を探ってみる - Qiita##やりたいことあるキーワードでGoogle検索した上位10サイトのタイトルの特徴を知りたい。##ライブラリBeautifulSoup4requestspandasjanomeskle…
---------
Python超初心者:Google検索するプログラムを作る | 理系 ...
![](https://rikei-fufu.com/wp-content/uploads/2019/06/python.jpg)
Python超初心者:Google検索するプログラムを作るPythonを始めたばっかりの超初心者が、Pythonの導入からGoogle検索するプログラムを作るまでを紹介します。
---------
【Python・スクレイピング】Googleキーワードプランナーを ...
![](https://surat.jp/wp-content/uploads/2020/08/alex-kotliarskyi-ourQHRTE2IM-unsplash.jpg)
【Python・スクレイピング】Googleキーワードプランナーを使ってGoogle検索結果を自動取得今回はPythonを使って、Googleキーワードプランナーのデータを使ってGoogle検索結果を自動取得するプログラムを作成しました。ブログや自社の製品・サービスについてキーワードやGoogle検索結果などを調査するときに使ってみてくださ
---------
PythonでGoogle検索タイトルとURL一覧を抽出してみた ...
![](https://watlab-blog.com/wp-content/uploads/2019/08/ec-google-title-link.png)
PythonでGoogle検索タイトルとURL一覧を抽出してみた近年Google検索は完全に情報収集の基本になっています。Webスクレイピングで自動情報収集をする場合、Google検索結果を扱えるようになると世界中の情報をシステマティックに処理できるようになります。ここでは、Google検索で得られるタイトルとURLを一覧で取得する方法を紹介します。
---------
Python(パイソン)でGoogleの検索結果をスクレイピングする ...
![](https://s0.wordpress.com/mshots/v1/https%3A%2F%2Ficedog-works.com%2Fpython-scraping?w=160&h=90)
ページが見つかりません。 - 氷犬の犬小屋Works
---------
Python requestsを使ってグーグル検索をする | 鎖プログラム
![](https://pg-chain.com/wp-content/uploads/2018/08/pythonロゴ.jpg)
【Python】requestsの使い方(グーグル検索してみる)Pythonの「requests」の使い方について。 この記事の内容はコチラです PythonでWEBサイトへ接続したい PythonでGoogle検索したい requestsの使い方を知る WEB接続の1例としてグーグル検索を取り上げます
---------
[python] google検索結果をbeautifulsoupでスクレイピングして ...
![](https://trelab.info/wp-content/uploads/2020/06/python-logo.png)
[python] google検索結果をbeautifulsoupでスクレイピングして、タイトルとURLをセットで取得するpythonでGoogle検索の結果をbeautifulsoupでスクレイピングして、タイトルとURLのセットを取得して表示させてみます。import requestsimport bs4# キーワードを使って検索してhtmlを取得するke
---------
上記のようにPythonでGoogle検索し、Google検索した結果を抽出することができます。
google-search-beautifulsoup.pyを短時間で大量に実行すると、「HTTPError: HTTP Error 403: Forbidden」エラーが出力され、Googleから規制を受ける(Google検索ができなくなる)ので要注意です。
「HTTPError: HTTP Error 403: Forbidden」を回避しつつ、短時間で大量にGoogle検索をしたい場合、以下の記事で紹介している「GUI操作の自動化ができるPyAutoGUI」の利用を検討してください。
>> 【要点】PyAutoGUIとは?初心者向けに特徴から使い方までを図解
【まとめ】PythonでGoogle検索する方法【BeautifulSoup】
今回の記事を通して、「BeautifulSoupを用いてPythonでGoogle検索する方法」をご紹介することで、以下の悩みを解消しました。
★悩み★
・PythonからGoogle検索ってできるんだろうか。
・Google検索結果からページタイトルとURLを抽出できないかな。
・BeautifulSoupを利用したGoogle検索の方法が分からないな。
「PythonでGoogle検索する方法は?」で悩んでいるあなたにこの記事が少しでも役に立てれば幸いです。