Подтвердить что ты не робот

Как преобразовать веб-страницу в PDF с помощью Python

Я нашел решение для печати веб-страницы в локальном файле PDF, используя Python. одним из лучших решений является использование Qt, найденного здесь, https://bharatikunal.wordpress.com/2010/01/.

Это не сработало с самого начала, поскольку у меня возникла проблема с установкой PyQt4, потому что он выдавал сообщения об ошибках, такие как "ImportError: Нет модуля с именем PyQt4.QtCore" и "ImportError: Нет модуля с именем PyQt4.QtCore".

Это потому, что PyQt4 не установлен должным образом. Раньше у меня были библиотеки, расположенные в C:\Python27\Lib, но это не для PyQt4.

На самом деле его просто нужно скачать с http://www.riverbankcomputing.com/software/pyqt/download (вспомните правильную версию Python, которую вы используете) и установите его в C:\Python27 (мой дело). Что это.

Теперь скрипты работают нормально, поэтому я хочу поделиться им. для получения дополнительных опций при использовании Qprinter см. http://qt-project.org/doc/qt-4.8/qprinter.html#Orientation-enum.

4b9b3361

Ответ 1

благодаря сообщениям ниже, и я могу добавить на адрес ссылки на веб-страницу, который будет напечатан, и настоящее время на сгенерированном PDF файле, независимо от того, сколько страниц у него есть.

Добавить текст в существующий PDF с помощью Python

https://github.com/disflux/django-mtr/blob/master/pdfgen/doc_overlay.py

Чтобы поделиться script, как показано ниже:

import time
from pyPdf import PdfFileWriter, PdfFileReader
import StringIO
from reportlab.pdfgen import canvas
from reportlab.lib.pagesizes import letter
from xhtml2pdf import pisa
import sys 
from PyQt4.QtCore import *
from PyQt4.QtGui import * 
from PyQt4.QtWebKit import * 

url = 'http://www.yahoo.com'
tem_pdf = "c:\\tem_pdf.pdf"
final_file = "c:\\younameit.pdf"

app = QApplication(sys.argv)
web = QWebView()
#Read the URL given
web.load(QUrl(url))
printer = QPrinter()
#setting format
printer.setPageSize(QPrinter.A4)
printer.setOrientation(QPrinter.Landscape)
printer.setOutputFormat(QPrinter.PdfFormat)
#export file as c:\tem_pdf.pdf
printer.setOutputFileName(tem_pdf)

def convertIt():
    web.print_(printer)
    QApplication.exit()

QObject.connect(web, SIGNAL("loadFinished(bool)"), convertIt)

app.exec_()
sys.exit

# Below is to add on the weblink as text and present date&time on PDF generated

outputPDF = PdfFileWriter()
packet = StringIO.StringIO()
# create a new PDF with Reportlab
can = canvas.Canvas(packet, pagesize=letter)
can.setFont("Helvetica", 9)
# Writting the new line
oknow = time.strftime("%a, %d %b %Y %H:%M")
can.drawString(5, 2, url)
can.drawString(605, 2, oknow)
can.save()

#move to the beginning of the StringIO buffer
packet.seek(0)
new_pdf = PdfFileReader(packet)
# read your existing PDF
existing_pdf = PdfFileReader(file(tem_pdf, "rb"))
pages = existing_pdf.getNumPages()
output = PdfFileWriter()
# add the "watermark" (which is the new pdf) on the existing page
for x in range(0,pages):
    page = existing_pdf.getPage(x)
    page.mergePage(new_pdf.getPage(0))
    output.addPage(page)
# finally, write "output" to a real file
outputStream = file(final_file, "wb")
output.write(outputStream)
outputStream.close()

print final_file, 'is ready.'

Ответ 2

Вы также можете использовать pdfkit:

Использование
import pdfkit
pdfkit.from_url('http://google.com', 'out.pdf')

Установите

MacOS: brew install Caskroom/cask/wkhtmltopdf

Debian/Ubuntu: apt-get install wkhtmltopdf

Смотрите официальную документацию для MacOS/Ubuntu/других ОС: https://github.com/JazzCore/python-pdfkit/wiki/Installing-wkhtmltopdf

Ответ 3

WeasyPrint

pip install weasyprint  # No longer supports Python 2.x.

python
>>> pdf = weasyprint.HTML('http://www.google.com').write_pdf()
>>> len(pdf)
92059
>>> file('google.pdf', 'wb').write(pdf)

Ответ 4

здесь работает один:

import sys 
from PyQt4.QtCore import *
from PyQt4.QtGui import * 
from PyQt4.QtWebKit import * 

app = QApplication(sys.argv)
web = QWebView()
web.load(QUrl("http://www.yahoo.com"))
printer = QPrinter()
printer.setPageSize(QPrinter.A4)
printer.setOutputFormat(QPrinter.PdfFormat)
printer.setOutputFileName("fileOK.pdf")

def convertIt():
    web.print_(printer)
    print "Pdf generated"
    QApplication.exit()

QObject.connect(web, SIGNAL("loadFinished(bool)"), convertIt)
sys.exit(app.exec_())

Ответ 5

Вот простое решение с использованием QT. Я нашел это как часть ответа на другой вопрос о StackOverFlow. Я тестировал его в Windows.

from PyQt4.QtGui import QTextDocument, QPrinter, QApplication

import sys
app = QApplication(sys.argv)

doc = QTextDocument()
location = "c://apython//Jim//html//notes.html"
html = open(location).read()
doc.setHtml(html)

printer = QPrinter()
printer.setOutputFileName("foo.pdf")
printer.setOutputFormat(QPrinter.PdfFormat)
printer.setPageSize(QPrinter.A4);
printer.setPageMargins (15,15,15,15,QPrinter.Millimeter);

doc.print_(printer)
print "done!"

Ответ 6

Я попытался ответить @NorthCat с помощью pdfkit.

Требуется wkhtmltopdf для установки. Установку можно скачать отсюда. https://wkhtmltopdf.org/downloads.html

Установите исполняемый файл. Затем напишите строку, чтобы указать, где находится wkhtmltopdf, как показано ниже. (ссылка не может создать pdf с использованием Python PDFKIT Ошибка: " не найден исполняемый файл wkhtmltopdf: "

import pdfkit


path_wkthmltopdf = "C:\\Folder\\where\\wkhtmltopdf.exe"
config = pdfkit.configuration(wkhtmltopdf = path_wkthmltopdf)

pdfkit.from_url("http://google.com", "out.pdf", configuration=config)