Преобразование html в pdf с помощью xhtml2pdf, изображения не отображаются

def create_pdf(pdf_data):
    filename = app.config['UPLOAD_FOLDER'] + "/file.pdf"
    f = file(filename, "wb")
    pdf = pisa.CreatePDF(StringIO(pdf_data.encode('utf-8')), f)
    return pdf

pdf = create_pdf(render_template('receipt.htm', entry=entry, filename=filename))

Шаблон html показывает изображения, но при преобразовании в pdf с помощью xhtml2pdf изображения не отображаются!


person user2499707    schedule 05.07.2013    source источник
comment
Не могли бы вы показать свой html-код?   -  person Lukasz Koziara    schedule 30.07.2013


Ответы (1)


Я думаю, что это полезно для вас:

def fetch_resources(uri, rel):
    if uri.startswith(settings.MEDIA_URL):
        path = os.path.join(settings.MEDIA_ROOT,uri.replace(settings.MEDIA_URL, ""))
    elif uri.startswith(settings.STATIC_URL):
        path = os.path.join(settings.LOADING_STATIC_FOR_PDF,uri.replace(settings.STATIC_URL, ""))
    return path

def preview_pdf(request):
    context = RequestContext(request)
    if request.method == 'GET':
        context = {
            # sending data to html 
        }
        rendered_html = render_to_string("path/xxx.html", locals())
        template = get_template('path/xxx.html')
        html = template.render(context)
        result = StringIO.StringIO()
        file = open('test.pdf', "w+b")
        pisaStatus = pisa.CreatePDF(html.encode('utf-8'), dest=file, encoding='utf-8',link_callback=fetch_resources)
        file.seek(0)
        pdf = file.read()
        file.close()
        return HttpResponse(pdf, 'application/pdf')
person duddu venkatesh    schedule 12.04.2016