本文主要是介绍Python对网页进行截图生成长图(存在滚动条情况),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
插件
- playwright(本次使用这个)
- selenium
原理
主要就是模拟人工通过浏览器访问相关网址
代码
- playwright
import datetime
from time import sleepfrom playwright.sync_api import sync_playwrightdef capture_scrollable_page(url, output_path):with sync_playwright() as p:# 创建浏览器对象browser = p.chromium.launch()page = browser.new_page()# 打开网页page.goto(url)# 可以使用page.evaluate执行javascript脚本 这里为了使截图显示全 设置最外面的滚动容器设置为visiblepage.evaluate('''document.getElementById('container-view').style.overflow='visible'''')sleep(10)# 这里选择要进行截图的容器 相当于id选择器 path为图片输出的路径page.locator('#container-view').screenshot(path=output_path)# 使用示例
url = "https://XXX.com.cn" # 可访问的网页、http://localhost也可以哦
output_path: str = "d:/data/screenshot-{}.png" # 替换为你想要保存的文件路径
output_path = output_path.format(datetime.datetime.now().strftime("%H%M%S"))
capture_scrollable_page(url, output_path)
- selenium
import timefrom selenium import webdriverdef get_image(url, pic_name):chrome_options = webdriver.ChromeOptions()chrome_options.add_argument('headless')chrome_options.add_argument('--no-sandbox')chrome_options.add_argument('--disable-dev-shm-usage')driver = webdriver.Chrome('D:/data/chorm/chromedriver.exe', options=chrome_options)# 控制浏览器写入并转到链接driver.get(url)time.sleep(40)# 接下来是全屏的关键,用js获取页面的宽高,如果有其他需要用js的部分也可以用这个方法width = driver.execute_script("return document.documentElement.scrollWidth")height = driver.execute_script("return document.documentElement.scrollHeight")# 将浏览器的宽高设置成刚刚获取的宽高driver.set_window_size(width, height)time.sleep(1)# 截图并关掉浏览器driver.save_screenshot(pic_name)driver.close()get_image('http://localhost:8081/', 'd:/data/screenshot1111111.png')
这篇关于Python对网页进行截图生成长图(存在滚动条情况)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!