Pythonを使用して、WebページをローカルファイルPDFに印刷するソリューションを見つけていました。良い解決策の1つは、ここにあるQtを使用することです https://bharatikunal.wordpress.com/2010/01/ 。
「ImportError:No module named PyQt4.QtCore」や「ImportError:No module named PyQt4.QtCore」などのエラーメッセージが表示されたため、PyQt4のインストールに問題があったため、最初は動作しませんでした。
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 を参照してください。
以下の投稿のおかげで、ウェブページのリンクアドレスを追加して、印刷するページの数に関係なく、生成されるPDFの時間を表示できます。
https://github.com/disflux/Django-mtr/blob/master/pdfgen/doc_overlay.py
以下のようにスクリプトを共有するには:
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.'
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/other OSの公式ドキュメントを参照してください: https://github.com/JazzCore/python-pdfkit/wiki/Installing-wkhtmltopdf
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)
正常に動作するものを次に示します。
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_())
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!"