python-3.x - 如何让 WKHTMLTOPDF 在 Heroku 上工作?
问题描述
我创建了一个使用 PDFKIT 生成 PDF 的网站,并且我知道如何在 Window 上安装和设置环境变量路径。我设法在 Heroku 上部署了我的第一个网站,但现在在尝试生成 PDF 时出现错误“找不到 wkhtmltopdf 可执行文件:“b''”。我不知道如何在 Heroku 上安装和设置 WKHTMLTOPDF,因为这是我第一次处理Linux。在问这个之前我真的尝试了一切,但即使遵循这个对我也不起作用 。Python 3 flask install wkhtmltopdf on heroku
如果可能,请逐步指导我如何安装和设置它。
我跟踪了所有资源和所有内容,但无法使其正常工作。每次我得到同样的错误。我正在使用 Django 版本 2。Python 版本 3.7。
如果我做heroku stack,这就是我得到的
可用堆栈 cedar-14 容器 heroku-16 * heroku-18
错误,我在生成 PDF 时遇到。未找到 wkhtmltopdf 可执行文件:“b''” 如果此文件存在,请检查此进程是否可以读取它。否则请安装 wkhtmltopdf - https://github.com/JazzCore/python-pdfkit/wiki/Installing-wkhtmltopdf
我的网站在 localhost 上运行良好,没有任何问题,据我所知,我确信我在安装 wkhtmltopdf 时做错了。
谢谢
解决方案
这是不平凡的。如果您想避免以下所有令人头疼的问题,您可以使用我的服务 api2pdf:https ://github.com/api2pdf/api2pdf.python 。否则,如果您想尝试解决它,请参见下文。
1) 将此添加到您的 requirements.txt 中,以便为 heroku 和 pdfkit 安装一个特殊的 wkhtmltopdf 包。
git+git://github.com/johnfraney/wkhtmltopdf-pack.git
pdfkit==0.6.1
2)我在我的烧瓶应用程序中创建了一个 pdf_manager.py。在 pdf_manager.py 我有一个方法:
def _get_pdfkit_config():
"""wkhtmltopdf lives and functions differently depending on Windows or Linux. We
need to support both since we develop on windows but deploy on Heroku.
Returns:
A pdfkit configuration
"""
if platform.system() == 'Windows':
return pdfkit.configuration(wkhtmltopdf=os.environ.get('WKHTMLTOPDF_BINARY', 'C:\\Program Files\\wkhtmltopdf\\bin\\wkhtmltopdf.exe'))
else:
WKHTMLTOPDF_CMD = subprocess.Popen(['which', os.environ.get('WKHTMLTOPDF_BINARY', 'wkhtmltopdf')], stdout=subprocess.PIPE).communicate()[0].strip()
return pdfkit.configuration(wkhtmltopdf=WKHTMLTOPDF_CMD)
我有平台声明的原因是我在 Windows 机器上开发并且我的 PC 上有本地 wkhtmltopdf 二进制文件。但是当我部署到 Heroku 时,它在他们的 linux 容器中运行,所以我需要先检测我们在哪个平台上运行二进制文件。
3) 然后我创建了另外两种方法 - 一种将 url 转换为 pdf,另一种将原始 html 转换为 pdf。
def make_pdf_from_url(url, options=None):
"""Produces a pdf from a website's url.
Args:
url (str): A valid url
options (dict, optional): for specifying pdf parameters like landscape
mode and margins
Returns:
pdf of the website
"""
return pdfkit.from_url(url, False, configuration=_get_pdfkit_config(), options=options)
def make_pdf_from_raw_html(html, options=None):
"""Produces a pdf from raw html.
Args:
html (str): Valid html
options (dict, optional): for specifying pdf parameters like landscape
mode and margins
Returns:
pdf of the supplied html
"""
return pdfkit.from_string(html, False, configuration=_get_pdfkit_config(), options=options)
我使用这些方法转换为 PDF。
推荐阅读
- c# - 在两行中显示 div 元素,其中一行 4 个项目
- memory-leaks - 使用这样的高阶javascript函数是否存在内存泄漏?
- java - 更新 ArrayList 中 Array 的数组元素
- python - 使用 python 解析具有不同父键的 JSON 数据
- loops - Kotlin for 循环未在 Kotlin 脚本中打印
- excel - Office 2013 上的 SAS 插件 7.1,用于更新 powerpoint 幻灯片的 VBA 代码
- azure - ODBC 驱动程序和访问 Azure 登录的奇怪行为
- python - 为一个类实例预取多对多关系
- python - 如何更改数据框列中几个项目的名称
- python - 是否可以使用 dask.compute 将 dask.DataFrame.categorize 与另一个 dask 计算结合起来?