
本教程详细介绍了如何使用pyside6/pyqt6将qwidget内容高质量地导出为pdf文件,解决输出模糊的问题。核心方法包括正确设置qprinter的分辨率,并根据目标pdf页面的dpi调整qwidget的尺寸和内部ui元素的缩放,以确保清晰专业的打印效果。
在桌面应用开发中,将用户界面(QWidget)内容导出为PDF文件是一项常见需求。然而,许多开发者在使用PySide6或PyQt6的QPrinter进行导出时,可能会遇到生成的PDF图像模糊、质量不佳的问题。这通常是由于未正确配置打印机的分辨率以及QWidget自身渲染尺寸与目标PDF尺寸不匹配所致。本教程将深入探讨导致此问题的原因,并提供一个可靠的解决方案,确保生成高质量的PDF输出。
当我们将一个QWidget渲染到QPrinter时,QWidget会根据其当前的显示尺寸进行绘制。如果QWidget的尺寸相对较小,而目标PDF页面(如A4)需要更高的像素密度(DPI),那么QWidget的低分辨率绘制内容在被拉伸到高分辨率PDF页面时就会显得模糊。
初始尝试可能包括设置QPrinter.PrinterMode.HighResolution,但这不是一个方法调用,而是一个枚举值,直接使用并不能设置打印机分辨率。正确的做法是使用setResolution()方法。然而,仅仅设置打印机分辨率还不足以解决问题,QWidget本身也需要以足够高的分辨率进行渲染。
要生成高质量的PDF,关键在于两点:
以A4纸张为例,其标准尺寸为210mm x 297mm。如果我们要以300 DPI(每英寸点数)进行输出,那么A4页面的像素尺寸将是:
因此,我们将QWidget的固定尺寸设置为QSize(2480, 3508),并设置打印机分辨率为300 DPI,即可实现高质量的A4 PDF输出。
以下是一个完整的PySide6示例,演示如何将一个包含QTableWidget的QWidget高质量地导出为A4尺寸的PDF。
import os import datetime from PySide6.QtCore import QSize from PySide6.QtGui import QPageSize, QFont # 引入QFont用于设置字体大小 from PySide6.QtWidgets import QApplication, QWidget, QTableWidget, QVBoxLayout, QTableWidgetItem, QHeaderView from PySide6.QtPrintSupport import QPrinter
在Example类的__init__方法中,我们将QWidget的固定尺寸设置为A4纸张在300 DPI下的像素尺寸。同时,为了确保UI元素在放大后依然清晰可见,我们相应地增大了字体大小和表格的行高。
class Example(QWidget):
def __init__(self):
super().__init__()
# 关键:设置QWidget的固定尺寸,使其与A4纸张在300DPI下的像素尺寸匹配
# A4尺寸 (210mm x 297mm) 在300DPI下约为 2480x3508 像素
self.setFixedSize(QSize(2480, 3508))
# 初始化QTableWidget,增加行数以填充更大的画布
self.table_widget = QTableWidget(35, 5, self)
self.table_widget.setHorizontalHeaderLabels(["Item", "Batch", "MRP", "Quantity", "Amount"])
# 关键:设置表头和表格内容的字体大小,以适应高分辨率输出
self.table_widget.horizontalHeader().setFont(QFont("Arial", 30))
self.table_widget.setFont(QFont("Arial", 30))
# 设置列宽调整模式
self.table_widget.horizontalHeader().setSectionResizeMode(0, QHeaderView.Stretch)
for i in range(1, 5):
self.table_widget.horizontalHeader().setSectionResizeMode(i, QHeaderView.ResizeMode.ResizeToContents)
# 关键:设置表格垂直表头(行)的默认尺寸,确保行高足够
self.table_widget.verticalHeader().setDefaultSectionSize(100)
# 填充表格数据
for i in range(0, 35):
for j in range(0, 5):
self.table_widget.setItem(i, j, QTableWidgetItem(f"Item Name_{i}_{j}"))
layout = QVBoxLayout()
layout.addWidget(self.table_widget)
self.setLayout(layout)exportToPDF方法负责配置QPrinter。这里最核心的改动是使用printer.setResolution(300)来明确设置输出DPI。
def exportToPDF(self, filename):
printer = QPrinter()
# 设置页面尺寸为A4
pageSize = QPageSize(QPageSize.A4)
printer.setPageSize(pageSize)
# 关键:设置打印机输出分辨率为300 DPI
printer.setResolution(300)
# 设置输出格式为PDF
printer.setOutputFormat(QPrinter.PdfFormat)
printer.setOutputFileName(filename)
# 将QWidget内容渲染到打印机设备
self.render(printer)在主执行块中,创建QApplication和Example实例,然后调用exportToPDF方法。
if __name__ == "__main__":
app = QApplication([])
example = Example()
example.show() # 显示QWidget,可选
# 生成带有时间戳的文件名
pdf_filename = "invoice_" + datetime.datetime.now().strftime('%Y%m%d%H%M') + ".pdf"
example.exportToPDF(pdf_filename)
# 自动打开生成的PDF文件(Windows系统)
os.system("start " + pdf_filename)
app.exec()import os
import datetime
from PySide6.QtCore import QSize
from PySide6.QtGui import QPageSize, QFont
from PySide6.QtWidgets import QApplication, QWidget, QTableWidget, QVBoxLayout, QTableWidgetItem, QHeaderView
from PySide6.QtPrintSupport import QPrinter
class Example(QWidget):
def __init__(self):
super().__init__()
# 关键:设置QWidget的固定尺寸,使其与A4纸张在300DPI下的像素尺寸匹配
# A4尺寸 (210mm x 297mm) 在300DPI下约为 2480x3508 像素
self.setFixedSize(QSize(2480, 3508))
self.table_widget = QTableWidget(35, 5, self)
self.table_widget.setHorizontalHeaderLabels(["Item", "Batch", "MRP", "Quantity", "Amount"])
# 关键:设置表头和表格内容的字体大小,以适应高分辨率输出
self.table_widget.horizontalHeader().setFont(QFont("Arial", 30))
self.table_widget.setFont(QFont("Arial", 30))
self.table_widget.horizontalHeader().setSectionResizeMode(0, QHeaderView.Stretch)
for i in range(1, 5):
self.table_widget.horizontalHeader().setSectionResizeMode(i, QHeaderView.ResizeMode.ResizeToContents)
# 关键:设置表格垂直表头(行)的默认尺寸,确保行高足够
self.table_widget.verticalHeader().setDefaultSectionSize(100)
for i in range(0, 35):
for j in range(0, 5):
self.table_widget.setItem(i, j, QTableWidgetItem(f"Item Name_{i}_{j}"))
layout = QVBoxLayout()
layout.addWidget(self.table_widget)
self.setLayout(layout)
def exportToPDF(self, filename):
printer = QPrinter()
# 设置页面尺寸为A4
pageSize = QPageSize(QPageSize.A4)
printer.setPageSize(pageSize)
# 关键:设置打印机输出分辨率为300 DPI
printer.setResolution(300)
# 设置输出格式为PDF
printer.setOutputFormat(QPrinter.PdfFormat)
printer.setOutputFileName(filename)
# 将QWidget内容渲染到打印机设备
self.render(printer)
if __name__ == "__main__":
app = QApplication([])
example = Example()
example.show()
pdf_filename = "invoice_" + datetime.datetime.now().strftime('%Y%m%d%H%M') + ".pdf"
example.exportToPDF(pdf_filename)
os.system("start " + pdf_filename)
app.exec()通过本教程,我们了解到要使用PySide6/PyQt6生成高质量的PDF,关键在于同步调整QWidget的渲染尺寸和QPrinter的输出分辨率。通过将QWidget的fixedSize设置为目标PDF页面在指定DPI下的像素尺寸,并相应地调整内部UI元素的大小,我们可以确保render()方法有足够的像素数据进行高质量输出。这种方法能够有效地解决PDF输出模糊的问题,生成专业且清晰的文档。
以上就是PySide6/PyQt6:高质量导出QWidget到PDF的教程的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号