Создать PDF-файл с помощью Jinja без создания HTML-файлаPython

Программы на Python
Ответить Пред. темаСлед. тема
Anonymous
 Создать PDF-файл с помощью Jinja без создания HTML-файла

Сообщение Anonymous »


Я создаю PDF-файл, используя шаблон HTML и weasyprint для преобразования HTML-файла в PDF-файл.
Код работает отлично, но также создает HTML-файл, подобный PDF-файлу. файл
Есть ли способ избежать создания html-файла, а только pdf-файла??
это мой код

Код: Выделить всё

class Crud_db:
def __init__(self, database = 'database.db'):
self.database = database

def connect(self):
self.connection = sqlite3.connect(self.database)
self.cursor = self.connection.cursor()
# print('connect seccesfully')

def execute(self, query):
self.query = query
self.cursor.execute(self.query)

def close(self):
self.connection.commit()
self.connection.close()

def save_the_last_bill_to_html_pdf(self):
env = Environment(loader=FileSystemLoader('templates'))
# 3. Load the template from the Environment
template = env.get_template('th_bill.html')

# retrive the last general bill and details bill
self.connect()
query_general_bill = ''' SELECT general_bill.id, general_bill.client_name , general_bill.total , general_bill.total_margin , general_bill.number_of_products , general_bill.date_g ,general_bill.time_g , users.username user_id
FROM general_bill join users
on general_bill.user_id = users.id
WHERE general_bill.id=(SELECT MAX(id) FROM general_bill) '''
self.cursor.execute(query_general_bill)
result_general_bill = self.cursor.fetchall()

#  retrive the detail bill

query_details_bill = ''' SELECT product.product_name products, details_bill.number_of_products, details_bill.prix, details_bill.margin, details_bill.date, details_bill.time
FROM details_bill join product
on product.id = products
WHERE details_bill.general_bill_id = (SELECT MAX(id) FROM general_bill)'''
self.cursor.execute(query_details_bill)
result_detail_bill = self.cursor.fetchall()
# print(result_detail_bill)

html = template.render(result_general = result_general_bill,
result_detail_bill = result_detail_bill)

with open('html_report_jinja.html', 'w') as f:
f.write(html)

css = CSS(string='''
@page {size: A4; margin: 1cm;}
th, td {border: 1px solid black;}
''')
HTML('html_report_jinja.html').write_pdf('weasyprint_pdf_report.pdf', stylesheets=[css])



Источник: https://stackoverflow.com/questions/728 ... -html-file
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение

Вернуться в «Python»