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

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

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

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

Beautiful Soup

Beautiful Soupは、Pythonのライブラリの一つ。スクレイピングに特化しています。HTMLデータの構文の解析を行うために、HTMLタグ/CSSのセレクタで抽出する部分を指定することが可能です。

Python 3.x

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

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

1回答

1884閲覧

BeautifulSoupを使い、リストに入れたURLの指定した要素を取得

hafuuuuu

総合スコア3

スクレイピング

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

Beautiful Soup

Beautiful Soupは、Pythonのライブラリの一つ。スクレイピングに特化しています。HTMLデータの構文の解析を行うために、HTMLタグ/CSSのセレクタで抽出する部分を指定することが可能です。

Python 3.x

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

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2021/10/15 02:12

###前提・実現したいこと
pythonを初めて4か月目です。まだまだ初心者でわからないことが多く
お助けいただけますと幸いです。

BeautifulSoupを使い、リストに格納したURLの指定した要素を取得したい
・メニュー名
・参考料金
・施術方法
・悩み など。

URLの例はこちら↓
https://clinic.beauty.hotpepper.jp/H000481998/treatment-menus/

###該当のソースコード

python

1from bs4 import BeautifulSoup 2import requests 3import pandas as pd 4import time 5 6links = [ 7"https://clinic.beauty.hotpepper.jp/H000481998/treatment-menus/", 8"https://clinic.beauty.hotpepper.jp/H000482096/treatment-menus/", 9] 10 11menu_list = [] 12 13for i in range(len(links)): 14 15 r = requests.get(links[i]) 16 time.sleep(3) 17 soup = BeautifulSoup(r.text,'html.parser') 18 get_menu_list = soup.find(class_ = "treatment-menu") 19 20 for n in range(len(get_menu_list)): 21 get_link = get_menu_list[n].find_all(class_ = "treatment-menu__name") 22 23

###発生している問題・エラーメッセージ
上記のコードの get_menu_list → get_menu_list[n]にすると下記のエラーがでるのですが
なぜエラーが排出されるかわからず。。どなたかお分かりの方いましたらご教示いただけますと幸いです。

python

1 --------------------------------------------------------------------------- 2KeyError Traceback (most recent call last) 3<ipython-input-33-378ee7d4b23b> in <module> 4 9 5 10 for n in range(len(get_menu_list)): 6---> 11 get_link = get_menu_list[n].find_all(class_ = "treatment-menu__name") 7 8c:\users\hayato fukawa\appdata\local\programs\python\python39\lib\site-packages\bs4\element.py in __getitem__(self, key) 9 1404 """tag[key] returns the value of the 'key' attribute for the Tag, 10 1405 and throws an exception if it's not there.""" 11-> 1406 return self.attrs[key] 12 1407 13 1408 def __iter__(self): 14 15KeyError: 0

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

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

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

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

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

guest

回答1

0

ベストアンサー

解決コード

python

1from bs4 import BeautifulSoup 2import requests 3import pandas as pd 4import time 5 6links = [ 7"https://clinic.beauty.hotpepper.jp/H000481998/treatment-menus/", 8"https://clinic.beauty.hotpepper.jp/H000482096/treatment-menus/", 9] 10 11for i in range(len(links)): 12 13 r = requests.get(links[i]) 14 time.sleep(3) 15 soup = BeautifulSoup(r.text,'html.parser') 16 menu_list= soup.find_all(class_ = "treatment-menu__item") 17 for n in range(len(menu_list)): 18 name = menu_list[n].find(class_ = "treatment-menu__name").text 19 print(name) 20

とすれば、取得できます。

エラー原因

get_menu_list = soup.find(class_ = "treatment-menu")

で得られたget_menu_listをlistのように扱っているからです。

type(get_menu_list)

とすると

<class 'bs4.element.Tag'>

になり、listではありません。

<class 'bs4.element.Tag'>について

<class 'bs4.element.Tag'>はエラーメッセージ(tag[key] returns the value of the 'key' attribute for the Tag, and throws an exception if it's not there)にあるような挙動をします。こちらを参考にしてください。

投稿2021/10/15 04:47

k888

総合スコア123

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

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

hafuuuuu

2021/10/15 05:56

ありがとうございます! 教えていただいたコードで取得できました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問