前提・実現したいこと
プログラミングを始めてまだ数日のものです。
Python3.7
BeautifulSoup4を使ってスクレイピングを試しております。
Airbnbのあるエリアにある物件の名称と価格の一覧を取得しようとチャレンジております。
その中で正しくデータを収集できず困っておりまして、教えていただきたいです。
試したこと
まず、以下のようにclassで絞り込みを行いました。
import requests from bs4 import BeautifulSoup #webページを取得する load_url = "https://www.airbnb.jp/s/Takamatsu--%E6%97%A5%E6%9C%AC/homes" html = requests.get(load_url) soup = BeautifulSoup(html.content, "html.parser") #タグごとに取得 for element in soup.find_all(class_="_dx669kc"): print(element.text) for element in soup.find_all(class_="_1p7iugi"): print(element.text)
このコードを実行することで、特定のclassのデータと価格情報が取得できました。
その後、以下のコードを実行することで、物件の名称を取得しようとしたのですが、一部しか取得できませんでした。
また、結果のうちに"None"も表示されており、何に対するNoneなのかがよくわかりませんでした。
import requests from bs4 import BeautifulSoup #webページを取得する load_url = "https://www.airbnb.jp/s/Takamatsu--%E6%97%A5%E6%9C%AC/homes" html = requests.get(load_url) soup = BeautifulSoup(html.content, "html.parser") #リスティング物件を取得 for element in soup.find(class_="_dx669kc"): print(element.text) name = element.get("aria-label") print(name)
以上、お手数おかけいたしますが、よろしくお願いいたします。
あなたの回答
tips
プレビュー