¿Qué tal algo como esto?
from jinja2 import Environment, FileSystemLoader
env = Environment(loader=FileSystemLoader('templates'))
template = env.get_template('test.html')
output_from_parsed_template = template.render(foo='Hello World!')
print(output_from_parsed_template)
with open("my_new_file.html", "w") as fh:
fh.write(output_from_parsed_template)
test.html
<h1>{{ foo }}</h1>
salida
<h1>Hello World!</h1>
Si está utilizando un marco, como Flask, puede hacerlo en la parte inferior de su vista, antes de regresar.
output_from_parsed_template = render_template('test.html', foo="Hello World!")
with open("some_new_file.html", "wb") as f:
f.write(output_from_parsed_template)
return output_from_parsed_template
rb
awb
.)
al final de la primera línea en la sección de código inferior. Estaba tratando de agregarlo, pero SO requiere que las ediciones sean> 6 caracteres (limitación estúpida) ..Puede volcar una secuencia de plantilla en un archivo de la siguiente manera:
Template('Hello {{ name }}!').stream(name='foo').dump('hello.html')
Ref: http://jinja.pocoo.org/docs/dev/api/#jinja2.environment.TemplateStream.dump
fuente
Entonces, después de haber cargado la plantilla, llama a render y luego escribe la salida en un archivo. La declaración 'con' es un administrador de contexto. Dentro de la sangría tiene un archivo abierto como un objeto llamado 'f'.
template = jinja_environment.get_template('CommentCreate.html') output = template.render(template_values)) with open('my_new_html_file.html', 'w') as f: f.write(output)
fuente