本文共 1393 字,大约阅读时间需要 4 分钟。
最近在项目中做了一个生成并导出word报表的功能,在这里分享给大家。
经过查看ESPC原有的生成报表代码和网上查阅的一些方法,解决方案的思路如下:
1. 利用pychartdir库生成图表,保存图片,转成字节数据
2. 然后使用office办公软件编写所需要的模板word,另存为xml文件
3. 利用jinja2库渲染修改好的模板,然后写入.doc文件即可
那下面我将我实现的过程记录给大家分享一下。
一
利用pychartdir库生成图表,保存图片,转成字节数据
首先需要导入pychartdir库
我们以生成一个条形图为例子:
结果为一张图片:
2.我们在word中如果只是引用路径,那么生成的word就会出现找不到图片,此时,我们应该使用下面这个函数将图片转化为字节数据:
此时我们就拿到了我们想要的数据
我们可以将所需要画图的封装成一个工具类,只留取数据接口比如:
二
然后使用office办公软件编写所需要的模板word,另存为xml文件
2,使用sublime或者其他文本编辑打开xml文件,在模板相应位置替换成渲染的数据模型,具体语法和Django模板的语法基本一致,如:
三
利用jinja2库渲染修改好的模板,然后写入.doc文件即可
2.加载我们刚刚编辑好的word模板
3.打开和渲染模板
其中w_id和w_pname属性是word图片的属性,只要每一张图片id name唯一即可
全部代码如下:
运行代码,即可生成我们想要的word报表
Jinja2 安装:
pychartdir 安装:
Python 中要使用pychartdir的绘图的话需要安装pychartdir模块,其安装方法不同于其他python模块的安装。
1.先下载pychartdir,可从官网 http://www.advsofteng.com/download.html 下载对应的zip包
2.解压后的doc目录下有一个pychartdir.chm帮助文档
3.帮助文档中Installation中有描述安装的方法:
在python的安装目录下的Libsite-packages目录下新建chartdirector目录
将解压后的ChartDirectorlib目录下的所有文件复制到前面创建chartdirector目录下
在site-packages目录下新建一个chartdirector.pth文件,记事本打开,里面添加chartdirector,保存退出
4.打开python IDE,输入from pychartdir import *,如果导入成功则说明安装成功,可正常使用pychartdir
pychartdir API及其demo
http://www.advsofteng.com/doc/cdcfdoc/#cover.htm
Jinja2文档
http://docs.jinkan.org/docs/jinja2/
作者:袁庭飞
来源:http://blog.nsfocus.net/step-generate-word-reports-diagrams-py/
转载地址:http://iopla.baihongyu.com/