Que tal algo como isso?
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>
resultado
<h1>Hello World!</h1>
Se você estiver usando uma estrutura, como o Flask, poderá fazer isso na parte inferior da sua visualização, antes de retornar.
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
parawb
.)
no final da primeira linha na seção de código inferior. Eu estava tentando adicioná-lo, mas SO requer que as edições tenham> 6 caracteres (limitação estúpida) ..Você pode despejar um fluxo de modelo em um arquivo da seguinte maneira:
Template('Hello {{ name }}!').stream(name='foo').dump('hello.html')
Ref: http://jinja.pocoo.org/docs/dev/api/#jinja2.environment.TemplateStream.dump
fonte
Assim, depois de carregar o modelo, você chama render e grava a saída em um arquivo. A instrução 'with' é um gerenciador de contexto. Dentro da indentação, você tem um arquivo aberto como um objeto chamado '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)
fonte