Flask HttpResponse 响应体中返回 openpyxl 生成的 Excel 文档
现在我需要提供一个链接,访问时通过 openpyxl 动态生成一个 Excel 文档,并作为响应体返回。
在这里将动态生成的 Excel 文档保存到服务器,并重定向到静态文件链接显然不是一个合适的做法。
所以我们需要直接将 openpyx 生成的 Excel 文档写入到 Flask 的 HttpResponse 对象响应体中。
研究源码后发现,openpyxl在保存excel文件时会使用save_workbook 这个函数,这个函数在 openpyxl.writer.excel 模块中定义。
打开这个文件,这里还定义了一个叫做 save_virtual_workbook 的函数,看来这就是我们要找的东西。
def save_virtual_workbook(workbook,):
"""Return an in-memory workbook, suitable for a Django response."""
temp_buffer = BytesIO(