Challenge programming

Python

「HTMLを解析する」Beautiful Soupを使って。

インターネット上の情報をスクレイピングして情報を書き出したはいいけれど、自分の目当ての情報だけを集めたい。 そんなときに便利なのが「Beautiful Soup」というライブラリ。

外部ライブラリなのでまずはインストールしましょう。

Windowsならば、コマンドプロンプトを使って、「pip install beautifulsoup4」とします。

macOSならばターミナルを使い、「pip3 install beautifulsoup4」とします。


Beautiful Soupを使ってHTMLを解析してみよう

import requests
from bs4 import BeautifulSoup

load_url = "https://www.ymori.com/books/python2nen/test1.html"
html = requests.get(load_url)
soup = BeautifulSoup(html.content, "html.parser")

print(soup)

解説

import requests事前にコマンドプロンプトでインストールしたインターネットにアクセス命令する外部ライブラリ「requests」、これをimportします。
from bs4 import BeautifulSoup事前にコマンドプロンプトでインストールしたHTMLを解析する外部ライブラリ「BeautifulSoup」、これが入っているbs4というパッケージからBeautifulSoupをimport
load_url = "https://www.ymori.com/books/python2nen/test1.html"変数load_urlに解析するWEBページアドレスを代入
html = requests.get(load_url)変数htmlにネット上のHTMLファイルを読み込む命令のrequests.get(load_url)を代入します。
soup = BeautifulSoup(html.content, "html.parser")変数soupにBeautifulSoupを使ったHTML解析の命令を代入します。
print(soup)データを表示します。

実行結果


そのまま表示はされていますが、これが解析したあとの状態になります。

ここから、自分の目的にあった「要素」を取り出していきます。

取り出し方は「.find("タグ名)"」するだけです。


では、早速やってみましょう。

titleタグ、h2タグ、liタグを検索して、取り出し表示してみましょう。

import requests
from bs4 import BeautifulSoup

load_url = "https://www.ymori.com/books/python2nen/test1.html"
html = requests.get(load_url)
soup = BeautifulSoup(html.content, "html.parser")

print(soup.find("title"))
print(soup.find("h2"))
print(soup.find("li"))

実行結果


指定した要素の3つが表示されました。

タグがついたままなので、文字だけを取り出すには最後に「.text」をつけます。

import requests
from bs4 import BeautifulSoup

load_url = "https://www.ymori.com/books/python2nen/test1.html"
html = requests.get(load_url)
soup = BeautifulSoup(html.content, "html.parser")

print(soup.find("title").text)
print(soup.find("h2").text)
print(soup.find("li").text)

実行結果


*尚、ここではバージョン「Python 3.10.1」を使用しています。

この本を参考に学び、完成させることができました。しかし、ここではプログラミング初心者の私が詳しく解説することは、おこがましく、難しく出来ません(ToT)
その点、この本では丁寧な解説が載っていますので、解説とともにコードを書き、完成させればより深く学ぶことができます(^.^)、実際、初心者の私でもわかりやすかったです。身に付け消えないスキルが2,000円程ならコスパよく、買っておいてよかったと満足してます。



もっと深く学びたい人にはこちらもどうぞ。| For those who want to learn more deeply, this is also recommended.

キャリアアップに必要なスキルを取得しよう。| Get the skills you need to advance your career.

Pythonエンジニア育成推進協会公式認定スクール | Officially certified school of Python Engineer Development Promotion Association.

ぺージの先頭に戻る(Return to top of page)


©2020年9月 Challenge programming

プライバシーポリシー