美丽的汤不等到页面完全加载
问题内容:
因此,在下面的代码中,我想打开一个公寓网站的网址并抓取该网页。唯一的问题是,Beautiful
Soup不会等到整个网页都呈现出来。直到将它们加载到页面上之前,这些公寓才会在html中呈现,这需要几秒钟的时间。我该如何解决?
from urllib.request import urlopen as uReq
from bs4 import BeautifulSoup as soup
my_url = 'https://xxxxx.com/properties/?sort=latest'
uClient = uReq(my_url)
page_html = uClient.read()
uClient.close()
page_soup = soup(page_html, "html.parser")
containers = page_soup.findAll("div",{"class":"grid-item"})
#len(containers) is empty since the contents haven't been loaded yet!
问题答案:
如果要等待页面完全加载其数据,则应考虑使用硒,在您的情况下,它可能看起来像这样:
from bs4 import BeautifulSoup
from selenium.webdriver import Chrome
from selenium.webdriver.chrome.options import Options
url = "<URL>"
chrome_options = Options()
chrome_options.add_argument("--headless") # Opens the browser up in background
with Chrome(options=chrome_options) as browser:
browser.get(url)
html = browser.page_source
page_soup = BeautifulSoup(html, 'html.parser')
containers = page_soup.findAll("div",{"class":"grid-item"})