iis服务器助手广告
返回顶部
首页 > 资讯 > 精选 >怎样自动把报表插入到 word 文档中
  • 385
分享到

怎样自动把报表插入到 word 文档中

2023-06-02 21:06:31 385人浏览 泡泡鱼
摘要

在很多业务场景中需要在 Word 文档中嵌入报表。比如下图这个报告:这是一个某大学年度毕业生就业报告,其中表格和统计图的数据来自数据库,如果通过报表工具,制作这样的表格和统计图是轻而易举的事情,但如果要把这些报表和统计图做到 word 报告

在很多业务场景中需要在 Word 文档中嵌入报表。比如下图这个报告:

怎样自动把报表插入到 word 文档中

这是一个某大学年度毕业生就业报告,其中表格和统计图的数据来自数据库,如果通过报表工具,制作这样的表格和统计图是轻而易举的事情,但如果要把这些报表和统计图做到 word 报告里就麻烦很多。以往有两个办法:一个是每次做好报表和统计图之后,导出为 word,再手工复制粘贴到 word 报告中;第二个是把整个报告都做成一个报表模板,然后再一起导出为 word。 方法一,纯手工操作效率低;方法二,报表工具排版能力有限,生成的 word 版面效果不够完美。

那么,还有什么好办法呢?

通常这类报告都有规定的模板样式,只是要定期替换里面的个别信息,比如上图所示的文档编号,报告时间,标题里的年度,图片,每个章节下的报表和统计图,这些信息是动态变化的,而其他文字描述部分以及整体样式都是固定不变的。所以,如果能把报表嵌入 word 文档做成流水线式的自动化过程,那就是一件两全其美,事半功倍的事情。

润乾报表就提供了把报表嵌入 word 的功能,实现步骤如下:

1、制作 word 模板,将需要插入内容的位置设置好书签

怎样自动把报表插入到 word 文档中

比如我们开篇看到的大学毕业生就业报告,我们可以先做成如上图所示的 word 模板,图示绿色线框位置就是需要定期更新的部分,预先在这些位置插入书签(比如书签名为:编号,时间,loGo,年度,报表,统计图),以此标记要插入到 word 的内容对应插入到什么位置。

2、制作报表,这一步就不详述了。

3、调用润乾报表的 raqsoft.report.view.oxml.word.DocxChanger 里的方法,将图片,文本,报表等内容插入到指定书签位置,生成新的 word 报告。

 eg:

//设置报表授权文件 File flic = new File("c:/tmp/report5.lic");

FileInputStream lis = new FileInputStream(flic);

Sequence.readLicense( Sequence.P_RPT, lis);

File f = new File("E:/test.docx");               //模板文件 File of = new File("D:/out.docx");             //输出文件 … …

FileOutputStream fos = new FileOutputStream(of);

DocxChanger dc = new DocxChanger(f, fos); //实例化DocxChanger //在书签“编号”,“时间”,“年度”处插入文字 dc.insertText("编号", "12345678");

dc.insertText("时间", "20170730");

dc.insertText("年度", "2017"); //在书签“logo”处插入图片文件 File f1 = new File("d:/logo.png"); dc.insertImage("logo", f1); //在书签“报表”,“统计图”处插入报表和统计图 File f2 = new File("d:/毕业去向.rpx"); FileInputStream fis = new FileInputStream(f2);

IReport report = ReportUtils.read(fis);

fis.close();

Context context = new Context();  

Engine engine = new Engine((ReportDefine) report, context);

report = engine.calc(); dc.insertReport("报表", report);

File f3 = new File("d:/留学.rpx");

FileInputStream fis2 = new FileInputStream(f3);

IReport report2 = ReportUtils.read(fis2);

fis2.close();

Context context2 = new Context(); 

Engine engine2 = new Engine((ReportDefine) report2, context2);

report2 = engine2.calc();

dc.insertReport("统计图", report2); //执行所有修改动作,然后关闭输出文件流

dc.execute();

fos.close();

至此,word 报告就自动生成了,以后每次只要执行一遍这段程序就行了,是不是方便了不少?

不过,这个办法还有个缺点,当插入内容变化时,我们就需要修改 java 代码,而改了代码之后又得重编译部署,难以做到热切换。这个办法还是不够方便。

为此,润乾报表还提供了外部配置的方法来实现 word 报表,可以预先编辑一个 xml 文件,在里面写个需要替代的书签等内容,然后程序会读取这个配置文件生成相应的 word 文档。

这样,当插入内容变化的时候,只要修改 xml 配置信息即可,而不用修改代码再编译了。我们一起来看一下:

1、编辑配置文件 xml

该文件中可配置多个书签和插入对象,当对象来源于内存时,可配置成 map,通过 key 从内存中取值,key 值可以是 IReport、byte[]、Image、String,值的类型程序会自动判断。

 

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>

<!-- file表示模板docx文件名,可配置绝对路径或相对路径(WEB端配置时相对于raqsoftConfig.xml中的reportFileHome) --> <docx file="D:/test.doc">

<!-- name表示docx书签,为空则不会插入。 file表示图片文件名,可配置绝对路径或相对路径(web端配置时相对于raqsoftConfig.xml中的reportFileHome) -->

<bookmark name="logo" type="image" file="D:/logo.png"/>

<!-- name表示docx书签, text要插入的文本文字 -->

<bookmark name="编号" type="text" text="12345678"/>

<bookmark name="时间" type="text" text="20170730"/>

<bookmark name="年度" type="text" text="2017"/>

<!-- key表示给定map中的key(未填时跟name相同,对应的value只能是IReport、byte\[\]、Image、String) -->

<bookmark name="统计图" type="map" key="f"/>

<!-- reportFile表示报表模板文件名,可配置绝对路径或相对路径(web端配置时相对于raqsoftConfig.xml中的reportFileHome) -->

<bookmark name="报表" type="report" reportFile="D:/毕业去向.rpx">

<!-- value表示报表参数值(串) -->

<reportParam name="arg1" type="value" value="设定参数1"/>

<!-- type为map时会从内存中根据name读取key,key未填写时跟name相同,key=””时会取map中key为空的值 -->

<reportParam name="arg2" type="map"/>   

  </bookmark> </docx>

注:在 web 应用中,如果 web.xml 里配置了 reportServlet,那么程序会自动加载 raqsoftconfig.xml,读取该文件里配置的 reportFileHome,数据源信息,授权文件等信息。

2、根据配置信息生成 Word 文档

try{    File of = new File("D:/out.docx");    FileOutputStream fos = new     FileOutputStream(of);    String xmlConfig = DocxChanger.xmlFile2String("D:/batch.xml");    File f4 = new File("d:/a.rpx");    FileInputStream fis = new FileInputStream(f4);    IReport report = ReportUtils.read(fis);    fis.close();    Context context = new Context();    Engine engine = new Engine((ReportDefine)     report, context);    report = engine.calc();    HashMap map =new HashMap();    map.put("f", report);    map.put("arg2", "2014-12-15 12:00:23");    DocxChanger.insert(map, xmlConfig, fos);    fos.close();}catch(Throwable x) {    x.printStackTrace();}

说了这么多,大家肯定会觉得理想很丰满,现实很骨感,这个功能是很完美,确实可以帮我解决这些个棘手的问题,但是都知道报表工具价格昂贵,再加上这样小奢的功能,岂不是贵上加贵,为此特意买一套昂贵的报表工具,似乎就不划算了,而开源报表里面又没有这个功能。但是你不知道的是,现在报表工具已经低端化了,润乾率先开始了 5000 元 / 套的低价报表了,恰巧这个功能里面有,恰巧你还看到了。


详情链接:Http://c.raqsoft.com.cn/article/1533027654063?r=gxy

--结束END--

本文标题: 怎样自动把报表插入到 word 文档中

本文链接: https://www.lsjlt.com/news/231266.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 怎样自动把报表插入到 word 文档中
    在很多业务场景中需要在 word 文档中嵌入报表。比如下图这个报告:这是一个某大学年度毕业生就业报告,其中表格和统计图的数据来自数据库,如果通过报表工具,制作这样的表格和统计图是轻而易举的事情,但如果要把这些报表和统计图做到 word 报告...
    99+
    2023-06-02
  • word文档怎么插入表格
    word文档插入表格的方法:1、 打开word文档,在想要插入表格的位置,点击插入选项;2、选择表格功能区;3、选择空白表格,手动选择表格的行数和列数,鼠标左键点击行数和列数上的箭头选择大小;4、之后会在word文档中创建一个表格对象;5、...
    99+
    2023-08-07
  • word文档中如何插入表格
    word文档插入表格的方法:1、打开Word文档,择新创建一个文档,或者打开一个已有的文档;2、将光标定位在你想要插入表格的位置;3、选择插入表格的方式,使用插入菜单中的表格选项;4、调整表格大小和样式,一旦表格插入到文档中,可以对其进行调...
    99+
    2023-08-07
  • 在Word文档中怎么插入分数呢
    在Word文档中插入分数,可以采取以下两种方式:1. 使用分数格式:- 在Word文档中,将光标定位到要插入分数的位置。- 在顶部菜...
    99+
    2023-09-16
    Word
  • 怎样在Word文档中输入分数
    在Word文档中输入分数,可以使用以下几种方法:1. 使用分数格式:在Word文档中,将光标定位到要输入分数的位置,然后选择“插入”...
    99+
    2023-09-16
    Word
  • windows7系统中我的文档怎样默认移动到D盘?
    首先o;)。在右侧有一个文档,打开它。 在“我的文档”上右击——属性,  在弹出的窗口中,选择“位置&r ...
    99+
    2023-05-30
    win7 我的文档 移动到D盘 文档 D盘 系统 windows7
  • 怎样从生产数据库中获得想要的查询语句,把结果集批量插入到磁盘txt文件中
    第一步:建立存储过程      实现传入参数,生成结果到磁盘的txt文件中;USE [XXXXX]GOSET ANSI_NULLS ONGOSET QUOTED_IDENTIF...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作