2017-08-24 6 views
0

私は、htmlのjsonファイルをレンダリングされたpdfに変換するためのスクリプトを書いています。 私はこれを書いた:問題は出力されPython convert json/html to pdf

from weasyprint import HTML 
from django.template import Template, Context 
from django.template.loader import render_to_string, get_template 
import json 


context = json.load(open("source path")) 

rendered_string = render_to_string("template.html", context) 

HTML(string=rendered_string).write_pdf("sample.pdf") 

を、JSON内のすべてのHTMLは単純なテキストとしてフォーマットされ、ボンドタイプで... JSONの一部はokです。 誰かがこの問題を解決する方法を知っていますか?

これはテンプレートです:

{%for elemento in elementi%} 
{%if not elemento.tipo%} 
    <h1>{{elemento.html}}</h1> 
{%else%} 
    <ul> 
    {%for f in elemento.form %} 
    <li>{{f}}</li> 
    {%endfor%} 
    </ul> 
{%endif%} 
{%endfor%} 

、これはJSONです:

{"elementi":[{"id":107729,"titolo":null,"tipo":false,"form":null,"html":"<span lessico='Questa' idx=\"0\" testo=\"testo\" show-modal=\"setModal()\" tables=\"updateTables(input)\">Questa</span> <span lessico='&egrave;' idx=\"1\" testo=\"testo\" show-modal=\"setModal()\" tables=\"updateTables(input)\">&egrave;</span> <span lessico='una' idx=\"2\" testo=\"testo\" show-modal=\"setModal()\" tables=\"updateTables(input)\">una</span> <span lessico='domanda' idx=\"3\" testo=\"testo\" show-modal=\"setModal()\" tables=\"updateTables(input)\">domanda</span>...","traduci":[],"inputLessicale":[],"esercizioId":101624,"italiano":null,"testo_principale":"Questa &egrave; una domanda...","testo_principale_pre":"","testo_principale_post":"","risposta_1":"","risposta_2":"","risposta_3":"","risposta_4":"","distrattore_1":"","distrattore_2":"","distrattore_3":"","distrattore_4":"","parole_gia_ricostruite":"","continua":false,"focus":true,"ignora_lessico":false,"etichetta_1":null,"etichetta_2":null,"etichetta_3":null,"etichetta_4":null,"etichetta_5":null}, 
{"id":107730,"titolo":"Scegli la risposta corretta","tipo":"M","form":["a scelta multipla","con risposta aperta","di tipo trova","di associazione"],"html":null,"traduci":[],"inputLessicale":[],"esercizioId":101624,"italiano":null,"testo_principale":"a scelta multipla","testo_principale_pre":"","testo_principale_post":"","risposta_1":"","risposta_2":"","risposta_3":"","risposta_4":"","distrattore_1":"con risposta aperta","distrattore_2":"di associazione","distrattore_3":"di tipo trova","distrattore_4":"","parole_gia_ricostruite":"","continua":false,"focus":false,"ignora_lessico":false,"etichetta_1":null,"etichetta_2":null,"etichetta_3":null,"etichetta_4":null,"etichetta_5":null}],"ordine_in_verifica":null} 
+0

は、通信の独自の手段を用いて高速化に対処されることがあります。 (IRCとGitHub) –

+0

問題がweasyprintであるかどうかわかりませんが、私はテンプレートに何か問題があったと思います – JungleFever

答えて

1

それは同様のスレッドからこの回答を参照してください、HTMLインジェクションを防ぐためにはDjangoの安全機能です:

https://stackoverflow.com/a/4848661/1047040

代わりに、

{{ elemento.html }} 

使用この:Djangoのドキュメントから

{{ elemento.html | safe }} 

がさらにHTMLを出力する前にエスケープを必要としないなどの文字列をマークします。自動文字処理がオフの場合、このフィルタは効果がありません。

リンク:weasyprintとHTMLレンダリングの問題のために頼むhttps://docs.djangoproject.com/en/dev/ref/templates/builtins/#safe