Oto rozwiązanie przy użyciu selen i specjalnego polecenia dla GhostDriver (powinno działać od GhostDriver 1.1.0 i PhantomJS 1.9. 6, przetestowane z PhantomJS 1.9.8):
#!/usr/bin/env python
# -*- coding: utf-8 -*-
"""Download a webpage as a PDF."""
from selenium import webdriver
def download(driver, target_path):
"""Download the currently displayed page to target_path."""
def execute(script, args):
driver.execute('executePhantomScript',
{'script': script, 'args': args})
# hack while the python interface lags
driver.command_executor._commands['executePhantomScript'] = ('POST', '/session/$sessionId/phantom/execute')
# set page format
# inside the execution script, webpage is "this"
page_format = 'this.paperSize = {format: "A4", orientation: "portrait" };'
execute(page_format, [])
# render current page
render = '''this.render("{}")'''.format(target_path)
execute(render, [])
if __name__ == '__main__':
driver = webdriver.PhantomJS('phantomjs')
driver.get('http://stackoverflow.com')
download(driver, "save_me.pdf")
zobacz także moją odpowiedź na to samo pytanie here.
Czy obejrzałeś Pypdf2? http://www.blog.pythonlibrary.org/tag/python-pdf-series/ – Amit
@Amit: Raczej szeroko, ponieważ używam go cały czas. Nawet Phaseit sami powiedzieli, że "PyPDF2 nie ma wiedzy o HTML". Nie będzie renderować żadnego HTML. – Rejected
@ Czy chcesz, aby zrzut ekranu wystąpił dokładnie w trakcie testu? A może chcesz załadować stronę i renderować do formatu PDF? –