微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

我想在后端生成我的 JS 图表我是否必须使用无头浏览器来确保它们正确呈现然后对它们进行截图?

如何解决我想在后端生成我的 JS 图表我是否必须使用无头浏览器来确保它们正确呈现然后对它们进行截图?

或者有其他更简单的方法吗?

我的网络应用程序是用 Python / Flask 编写的。有问题的图形库是 chartist.js (https://gionkunz.github.io/chartist-js/),它生成我在前端显示的动态交互式 HTML/SVG 图表。我的应用还需要在每日电子邮件中包含这些图表的静态 img 版本,因此无需前端/客户端参与,纯粹是后端。

我已经能够为每个图形生成 HTML,但是将 SVG 转换为 JPG/PNG 是一个挑战。由于 html 使用 chartist.js,我必须确保使用所有正确的 chartist.js 样式呈现它,而不仅仅是纯 html。 “whtmltoimage”似乎很完美(传入 html 并渲染图像)但命令行工具在我受限的工作网络中不可用。

所以替代方案似乎是某种形式的无头浏览器 -> 截图方法。我计划为此制作一个 node.js 脚本,或者是否有可能通过 Python 的替代解决方案?我是否必须通过无头浏览器使用 GET 请求/URL 请求图形 html 应用程序?

我遇到的可能的工具是:pupeteer、phantom.js、webshot。

非常感谢任何帮助。有关额外信息,我们最初使用 matplotlib 纯粹在后端生成图形,但这有点慢,我们更喜欢 JS 图形产品的外观。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。