简单实用浏览器渲染方式获取指定url网页html源码的方法

本文介绍了一个使用Python和Selenium编写的程序,通过读取url.txt文件中的URL,获取动态渲染的网页内容并保存为JSON。该程序利用Chrome驱动,处理了请求方式获取不到真实内容的问题。
摘要由CSDN通过智能技术生成

目前很多网站页面内容都是动态渲染出的,基于请求的方式无法获取到真实网页内容,因此开发了一个基于selenium的简单的指定url输出html的小程序。程序读取根目录url.txt文件,输出json消息。

代码如下:

import json
import undetected_chromedriver as uc
from selenium import webdriver
from selenium.webdriver import DesiredCapabilities
from selenium.webdriver.chrome.options import Options

def fetch_html(url):
    driver = initDriver()
    try:
        driver.get(url)
        html_content = driver.page_source  # 获取页面HTML内容
    finally:
        driver.quit()  # 确保最后关闭浏览器驱动

    return html_content

def process_urls(file_path, output_file):
    # 存储结果的列表
    results = []

    with open(file_path, 'r') as file:
        for line in file:
            url = line.strip()  # 读取每行的URL
            if url:
                html_content = fetch_html(url)  # 使用Selenium获取HTML内容
                results.append({'url': url, 'html': html_content})  # 添加到结果列表

    # 将结果写入JSON文件
    with open(output_file, 'w', encoding='utf-8') as f:
        json.dump(results, f, ensure_ascii=False, indent=4)

def initDriver():
    chrome_options = Options()
    d = DesiredCapabilities.CHROME
    d['goog:loggingPrefs'] = {'browser': 'ALL'}
    chrome_options.add_argument('--blink-settings=imagesEnabled=false')
    chrome_options.add_argument('--ignore-certificate-errors')
    chrome_options.add_argument("--disable-popup-blocking")
    driver = uc.Chrome(desired_capabilities=d, options=chrome_options)

    driver.execute_cdp_cmd("Page.addScriptToEvaluateOnNewDocument", {
        "source": """
                Object.defineProperty(navigator, 'webdriver', {
                    get: () => undefined
                })
            """})
    driver.maximize_window()
    return driver
if __name__ == '__main__':
    process_urls('url.txt', 'output.json')

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值