我开发了一个基于电子表格的应用程序,列出一些客户的未结费用,并将其保存在pdf中。代码工作得很好,但是当保存到pdf时,如果打开的费用非常大,页面的内容会被剪切,但不会添加另一个页面。
代码如下:
# !/usr/bin/env python
# -*- coding: utf-8 -*-
from __future__ import unicode_literals
from tkinter import *
from tkinter import ttk
from tkinter import messagebox
from reportlab.pdfgen import canvas
from reportlab.lib.pagesizes import letter
import openpyxl
import os
pastaApp = os.path.dirname(__file__)
def createPDF():
# Opens the spreadsheet and obtains the status of the last payment.
wb = openpyxl.load_workbook('C:/temp/cobranca.xlsx')
sheet = wb['Sheet1']
lastCol = sheet.max_column
# Checks the payment status of each customer.
unpaidMembers = {}
clients = []
months = []
emails = []
for r in range(2, sheet.max_row + 1):
for c in range(3, lastCol + 1):
payment = sheet.cell(row=r, column=c).value
if payment != 'ok':
client = sheet.cell(row=r, column=1).value
email = sheet.cell(row=r, column=2).value
month = sheet.cell(row=1, column=c).value
clients.append(client)
months.append(month)
emails.append(email)
unpaidMembers[client] = email
#print('Line:', r, 'Column:', c, 'Client:', client, 'Email:', email, 'Month:', month)
print('dictionary created successfully')
cnv = canvas.Canvas(pastaApp+"\\test.pdf", pagesize=letter)
cnv.drawString(10, 800, "Open Fee")
cnv.drawString(130, 800, " - Client/Month/E-mail")
y = 780
for client, month, email in zip(clients, months, emails):
cnv.drawString(10, y, client)
cnv.drawString(170, y, month)
cnv.drawString(350, y, email)
y -= 20
cnv.save()
root = Tk()
root.title("Create PDF")
btn_createPDF = Button(root, text="Check", command=createPDF)
btn_createPDF.pack(side="left", padx=10)
root.mainloop()
电子表格模型used:https网址:prnt.sc/125pi9y
1条答案
按热度按时间pw136qt21#
你需要检查
y
在你的for
循环。如果它低于36(半英寸边距),那么打电话给cnv.showPage()
,重置y
,并打印新的页眉。将页眉打印机分离为一个单独的函数留给读者作为练习。