python 如何动态获取javascript_使用Python抓取Javascript创建的动态内容

初始的HTML不包含您要抓取的数据,这就是为什么仅使用BeautifulSoup是不够的。您可以使用^{}加载页面,然后刮取内容。在

代码:import json

from bs4 import BeautifulSoup

from selenium import webdriver

from selenium.webdriver.support.ui import WebDriverWait

from selenium.webdriver.support import expected_conditions as EC

from selenium.webdriver.common.by import By

from selenium.common.exceptions import TimeoutException

html = None

url = 'http://demo-tableau.bitballoon.com/'

selector = '#dataTarget > div'

delay = 10 # seconds

browser = webdriver.Chrome()

browser.get(url)

try:

# wait for button to be enabled

WebDriverWait(browser, delay).until(

EC.element_to_be_clickable((By.ID, 'getData'))

)

button = browser.find_element_by_id('getData')

button.click()

# wait for data to be loaded

WebDriverWait(browser, delay).until(

EC.presence_of_element_located((By.CSS_SELECTOR, selector))

)

except TimeoutException:

print('Loading took too much time!')

else:

html = browser.page_source

finally:

browser.quit()

if html:

soup = BeautifulSoup(html, 'lxml')

raw_data = soup.select_one(selector).text

data = json.loads(raw_data)

import pprint

pprint.pprint(data)

输出:

^{pr2}$

代码假定按钮最初被禁用:Get Data,并且数据不会自动加载,而是由于单击了按钮。因此您需要删除这一行:setTimeout(function(){ getUnderlyingData(); }, 3000);。在

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值