BeautifulSoup解析通过js生成内容的本地html文件

在遇到本地HTML文件的内容由JavaScript动态生成时,BeautifulSoup无法直接解析。通过WebDriver的无头浏览器加载HTML,获取加载完成后的页面资源,保存为新的HTML文件,最后用BeautifulSoup解析这个新文件,从而解决问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题:当本地html文件中的元素都是由js生成时,我们无法通过beautifulsoup进行解析。

思路:

1.通过webdriver的无头浏览器,不在桌面打开浏览器的情况下,通过浏览器引擎加载html文件

2.获取浏览器的页面资源

3.将资源输出到另一个html2文件中,就获得了js加载完成后html了

4.beautifulsoup解析html2文件,即可

上代码:

from selenium import webdriver
from selenium.webdriver.chrome.options import Options
from bs4 import BeautifulSoup


def loadHtml(file_path):
    # 添加无头浏览器选项
    chrome_options = Options()
    chrome_options.add_argument('--headless')
    chrome_driver = webdriver.Chrome(chrome_options=chrome_options)
    # 加载原html资源,运行html文件中的js,生成相应元素
    chrome_driver.get(file_path)
    # 获取js生成后的页面资源
    html_source = str(chrome_driver.page_source)
    chrome_driver.close()
    return html_source

def getElementByAttrs(html_source, attrs):
    bs = BeautifulSoup(html_source,"
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值