在weasyprint中不应用Bootstrap CSS

内容来源于 Stack Overflow,并遵循CC BY-SA 3.0许可协议进行翻译与使用

  • 回答 (2)
  • 关注 (0)
  • 查看 (27)

我做了一个烧瓶应用程序,它使用weasyprint从html生成.pdf并将其作为附件发送。但显然bootstrap 4 css不适用。我找不到解决方案。它与pdfkit配合得很好但我需要weasyprint,因为pythonanywhere.com不支持pdfkit。

我已经尝试链接bootstrap,使用bootstrap css作为我的html中的文件,但没有区别。

这是我的python部分,它生成并发送pdf。

@app.route('/pdf_send', methods=('GET', 'POST'))
@login_required
def pdf_send():

    rendered = render_template(
    'pdf_send2.html', 
    name=name_g, 
    surname=surname_g,
    email=email_g,
    address=address_g,
    invoice_no=invoice_no_g,
    dict_g=dict_g,
    bendra_suma_g = ('%.2f' % round(float(bendra_suma_g[0]), 2)),
    send=send_g,
    today=today_g
    )

    css_file = ('static/bootstrap.css')
    filename = 'SF-' + invoice_no_g +'.pdf'
    html = HTML(string=rendered)
    css = CSS(filename=css_file)
    html.write_pdf(filename, stylesheets=[css])
    send_email(filename, email_g)

    return redirect(url_for('index'))
提问于
用户回答回答于

我知道这是一个旧线程,但我在寻找同一问题的答案时偶然发现它,所以我添加了我的解决方法,以防它帮助其他人。我将首先指出虽然这确实有效但Bootstrap确实不打算用于打印,而weasyprint忽略了@media查询中的任何内容,因此无论如何你都需要添加大量的css才能让它正确渲染所以它可能不值得。

使用原始问题中的代码,如果将bootstrap cdn css添加到stylesheets列表中,它将呈现:

html = HTML(string=rendered)
css = CSS(filename=css_file)
html.write_pdf(filename, stylesheets=[css, "https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css"])

但是,考虑到Bootstrap渲染的问题,我发现这个技巧对于应用字体更有用。

热门问答

树莓派4能够连上腾讯云物联网平台吗?

DylanRichard

腾讯 · 产品经理 (已认证)

万物互联的时代,欢迎来到IoT的世界
推荐

新版乐加固 不支持 64位应用?

Richel码农
推荐
1.麻烦确认应用自身apk中是否存在64位支持库【应用自身不存在64位支持库的话,加固后是肯定不存在的 2.乐固最新版本已适配arm64位,请更新版本或直接在官网进行加固; 3.乐固目前暂时未支持x86-64位,如需上架GooglePlay,需先删除x86支持 ... 展开详请

加固完成后多渠道打包显示androidname not found?

腾讯云@移动安全

腾讯 · 移动开发工程师 (已认证)

腾讯云移动安全前端开发
推荐
多渠道失败是工具的偶现性问题,目前这个问题已经提交技术进行排期解决。用户也可以切换电脑切换账号重新登录工具尝试。 实际上多渠道打包是加固工具的辅助工具,并不影响加固功能,用户可以选择在工具加固完成后自行进行多渠道打包的:https://blog.csdn.net/byongche...... 展开详请

请问微信云支付是否有沙箱环境?

HKC

红客学院 · 创始人 (已认证)

道可道 非常道 名可名 非常名
推荐
微信支付沙箱环境,是提供给微信支付商户的开发者,用于模拟支付及回调通知。以验证商户是否理解回调通知、账单格式,以及是否对异常做了正确的处理。 ◆ 如何对接沙箱环境? 1、修改商户自有程序或配置中,微信支付api的链接,如:被扫支付官网的url为:https://api.mch.w...... 展开详请

tencentcloud-sdk-php-master github代码上没有vendor文件夹?

推荐
因为和composer冲突,因此导出时没有包含vendor目录。如果需要,可以考虑git clone方式拿到,或者到https://cloud.tencent.com/document/sdk/PHP#.E9.80.9A.E8.BF.87.E6.BA.90.E7.A0.81.E5...... 展开详请

织云安装包在哪里下载?

使用织云,必须要满足1、2步骤1、机器要同步到c.isd.com系统。简单讲,就是在c.isd.com上有这台机器(如果c.isd.com没有,而公司的cmdb【cmdb.oa.com】有,则需要同步到c.isd.com即可,同步需要联系zhiyunhelper同步,而没有的话,...... 展开详请

扫码关注云+社区

领取腾讯云代金券