报表开发导出各种格式文件的API

简介:

文件输出的多样性,准确性和稳定性对于我们常用的报表软件来说很重要。报表的输入是指从报表的模板文件(XML格式的)创建WorkBook对象,输出则指将报表保存为各种格式文件,比如Pdf、Excel、Word这种常见的文件格式,比如FineReport还支持cpt、Svg、Csv、Image(包含png、 jpg、gif、 bmp、wbmp)等多种文件格式。

         因为常常会碰到报表的开发工作,这里总结了几种格式文件导出的API。

1、导出成内置数据集模板

导出成内置数据集模板,就是将原模板的数据源根据参数条件查询出结果并转为内置数据集,然后把模板导出,不需要对原模板进行计算(数据列扩展、公式计算等)。


[java] view plain copy 在CODE上查看代码片派生到我的代码片

  1. // 将未执行模板工作薄导出为内置数据集模板  

  2.             outputStream = new FileOutputStream(new File("E:\\EmbExport.cpt"));  

  3.             EmbeddedTableDataExporter templateExporter = new EmbeddedTableDataExporter();  

  4.             templateExporter.export(outputStream, workbook);  



2、导出模板文件

我们可以将原模板通过程序编辑后再次导出为模板文件,或者将某一路径下的模板保存至另一路径下。

[java] view plain copy 在CODE上查看代码片派生到我的代码片

  1. // 将模板工作薄导出模板文件,在导出前您可以编辑导入的模板工作薄,可参考报表调用章节  

  2.             outputStream = new FileOutputStream(new File("E:\\TmpExport.cpt"));  

  3.             ((WorkBook) workbook).export(outputStream);  


3、导出Excel文件

模板工作薄WorkBook执行后为结果工作薄ResultWorkBook,我们可以把计算后的结果导出成Excel文件。

[java] view plain copy 在CODE上查看代码片派生到我的代码片

  1. // 将结果工作薄导出为Excel文件  

  2.             outputStream = new FileOutputStream(new File("E:\\ExcelExport.xls"));  

  3.             ExcelExporter ExcelExport = new ExcelExporter();  

  4.             ExcelExport.export(outputStream, workbook.execute(parameterMap,new WriteActor()));  


4、导出Word文件

[java] view plain copy 在CODE上查看代码片派生到我的代码片

  1. // 将结果工作薄导出为Word文件  

  2.             outputStream = new FileOutputStream(new File("E:\\WordExport.doc"));  

  3.             WordExporter WordExport = new WordExporter();  

  4.             WordExport.export(outputStream, workbook.execute(parameterMap,new WriteActor()));  

5、导出Pdf文件


[java] view plain copy 在CODE上查看代码片派生到我的代码片

  1. // 将结果工作薄导出为Pdf文件  

  2.                             outputStream = new FileOutputStream(newFile("E:\\PdfExport.pdf"));  

  3.                             PDFExporter PdfExport = newPDFExporter();  

  4.                             PdfExport.export(outputStream,workbook.execute(parameterMap,new WriteActor()));  


6、导出Txt文件

[java] view plain copy 在CODE上查看代码片派生到我的代码片

  1. // 将结果工作薄导出为Txt文件(txt文件本身不支持表格、图表等,被导出模板一般为明细表)  

  2.             outputStream = new FileOutputStream(new File("E:\\TxtExport.txt"));<pre code_snippet_id="1709587" snippet_file_name="blog_20160606_6_1825679" name="code" class="java"></pre>  

7、导出Csv文件


[java] view plain copy 在CODE上查看代码片派生到我的代码片

  1. // 将结果工作薄导出为Csv文件  

  2.             outputStream = new FileOutputStream(new File("E:\\CsvExport.csv"));  

  3.             CSVExporter CsvExport = new CSVExporter();  

  4.             CsvExport.export(outputStream, workbook.execute(parameterMap,new WriteActor()));  


8、导出Svg文件

[java] view plain copy 在CODE上查看代码片派生到我的代码片

  1. //将结果工作薄导出为SVG文件    

  2.             outputStream = new FileOutputStream(new File("D:\\SvgExport.svg"));    

  3.             SVGExporter SvgExport = new SVGExporter();    

  4.             SvgExport.export(outputStream, workbook.execute(parameterMap,new WriteActor()));  

9、导出Image文件

[java] view plain copy 在CODE上查看代码片派生到我的代码片

  1. //将结果工作薄导出为image文件    

  2.             outputStream = new FileOutputStream(new File("D:\\PngExport.png"));    

  3.             ImageExporter ImageExport = new ImageExporter();    

  4.             ImageExport.export(outputStream, workbook.execute(parameterMap,new WriteActor()));  

10、释放进程

通过导出API在后台导出excel等文件,会产生很多进程,通过下面的方案释放进程。在导出完成之后添加下面代码:

[java] view plain copy 在CODE上查看代码片派生到我的代码片

  1. outputStream.close();  

  2. ModuleContext.stopModules();  

例如,一个完整的可执行代码:

[java] view plain copy 在CODE上查看代码片派生到我的代码片

  1. package com.fr.io;    

  2.     

  3. import java.io.File;    

  4. import java.io.FileOutputStream;    

  5. import com.fr.base.FRContext;   

  6. import com.fr.general.ModuleContext;  

  7. import com.fr.base.Parameter;  

  8. import com.fr.dav.LocalEnv;  

  9. import com.fr.io.exporter.CSVExporter;  

  10. import com.fr.io.exporter.EmbeddedTableDataExporter;  

  11. import com.fr.io.exporter.Excel2007Exporter;  

  12. import com.fr.io.exporter.ExcelExporter;  

  13. import com.fr.io.exporter.PDFExporter;  

  14. import com.fr.io.exporter.TextExporter;  

  15. import com.fr.io.exporter.WordExporter;  

  16. import com.fr.io.exporter.SVGExporter;  

  17. import com.fr.io.exporter.ImageExporter;  

  18. import com.fr.main.impl.WorkBook;  

  19. import com.fr.main.workbook.ResultWorkBook;  

  20. import com.fr.report.module.EngineModule;  

  21. import com.fr.stable.WriteActor;  

  22.   

  23.     

  24. public class ExportApi {    

  25.     public static void main(String[] args) {    

  26.         // 定义报表运行环境,才能执行报表    

  27.         String envpath = "D:\\FineReport_8.0\\WebReport\\WEB-INF";    

  28.         FRContext.setCurrentEnv(new LocalEnv(envpath));    

  29.         ModuleContext.startModule(EngineModule.class.getName());   

  30.         ResultWorkBook rworkbook = null;    

  31.         try {    

  32.             // 未执行模板工作薄    

  33.             WorkBook workbook = (WorkBook) TemplateWorkBookIO    

  34.                     .readTemplateWorkBook(FRContext.getCurrentEnv(),    

  35.                             "\\doc\\Primary\\Parameter\\Parameter.cpt");    

  36.             // 获取报表参数并设置值,导出内置数据集时数据集会根据参数值查询出结果从而转为内置数据集    

  37.             Parameter[] parameters = workbook.getParameters();    

  38.             parameters[0].setValue("华东");    

  39.             // 定义parametermap用于执行报表,将执行后的结果工作薄保存为rworkBook    

  40.             java.util.Map parameterMap = new java.util.HashMap();    

  41.             for (int i = 0; i < parameters.length; i++) {    

  42.                 parameterMap.put(parameters[i].getName(), parameters[i]    

  43.                         .getValue());    

  44.             }    

  45.             // 定义输出流    

  46.             FileOutputStream outputStream;    

  47.             // 将未执行模板工作薄导出为内置数据集模板    

  48.             outputStream = new FileOutputStream(new File("D:\\EmbExport.cpt"));    

  49.             EmbeddedTableDataExporter templateExporter = new EmbeddedTableDataExporter();    

  50.             templateExporter.export(outputStream, workbook);    

  51.             // 将模板工作薄导出模板文件,在导出前您可以编辑导入的模板工作薄,可参考报表调用章节    

  52.             outputStream = new FileOutputStream(new File("D:\\TmpExport.cpt"));    

  53.             ((WorkBook) workbook).export(outputStream);  

  54.             // 将结果工作薄导出为2003Excel文件    

  55.             outputStream = new FileOutputStream(new File("D:\\ExcelExport.xls"));    

  56.             ExcelExporter ExcelExport = new ExcelExporter();    

  57.             ExcelExport.export(outputStream, workbook.execute(parameterMap,new WriteActor()));     

  58.             // 将结果工作薄导出为Word文件    

  59.             outputStream = new FileOutputStream(new File("D:\\WordExport.doc"));    

  60.             WordExporter WordExport = new WordExporter();    

  61.             WordExport.export(outputStream, workbook.execute(parameterMap,new WriteActor()));    

  62.             // 将结果工作薄导出为Pdf文件    

  63.             outputStream = new FileOutputStream(new File("D:\\PdfExport.pdf"));    

  64.             PDFExporter PdfExport = new PDFExporter();    

  65.             PdfExport.export(outputStream, workbook.execute(parameterMap,new WriteActor()));    

  66.             // 将结果工作薄导出为Txt文件(txt文件本身不支持表格、图表等,被导出模板一般为明细表)    

  67.             outputStream = new FileOutputStream(new File("D:\\TxtExport.txt"));    

  68.             TextExporter TxtExport = new TextExporter();    

  69.             TxtExport.export(outputStream, workbook.execute(parameterMap,new WriteActor()));    

  70.             // 将结果工作薄导出为Csv文件    

  71.             outputStream = new FileOutputStream(new File("D:\\CsvExport.csv"));    

  72.             CSVExporter CsvExport = new CSVExporter();    

  73.             CsvExport.export(outputStream, workbook.execute(parameterMap,new WriteActor()));              

  74.             //将结果工作薄导出为SVG文件    

  75.             outputStream = new FileOutputStream(new File("D:\\SvgExport.svg"));    

  76.             SVGExporter SvgExport = new SVGExporter();    

  77.             SvgExport.export(outputStream, workbook.execute(parameterMap,new WriteActor()));             

  78.             //将结果工作薄导出为image文件    

  79.             outputStream = new FileOutputStream(new File("D:\\PngExport.png"));    

  80.             ImageExporter ImageExport = new ImageExporter();    

  81.             ImageExport.export(outputStream, workbook.execute(parameterMap,new WriteActor()));                        

  82.             outputStream.close();    

  83.             ModuleContext.stopModules();  

  84.         } catch (Exception e) {    

  85.             e.printStackTrace();    

  86.         }    

  87.     }    

  88. }  

编译运行该代码后,就会在E盘下生成不同格式的文件,这样就导出成功了。


本文转自 雄霸天下啦 51CTO博客,原文链接:http://blog.51cto.com/10549520/1786632,如需转载请自行联系原作者

相关文章
|
17天前
|
Java API Maven
如何使用Java开发抖音API接口?
在数字化时代,社交媒体平台如抖音成为生活的重要部分。本文详细介绍了如何用Java开发抖音API接口,从创建开发者账号、申请API权限、准备开发环境,到编写代码、测试运行及注意事项,全面覆盖了整个开发流程。
61 10
|
18天前
|
监控 Java 应用服务中间件
高级java面试---spring.factories文件的解析源码API机制
【11月更文挑战第20天】Spring Boot是一个用于快速构建基于Spring框架的应用程序的开源框架。它通过自动配置、起步依赖和内嵌服务器等特性,极大地简化了Spring应用的开发和部署过程。本文将深入探讨Spring Boot的背景历史、业务场景、功能点以及底层原理,并通过Java代码手写模拟Spring Boot的启动过程,特别是spring.factories文件的解析源码API机制。
49 2
|
18天前
|
API 开发工具 数据库
开发一份API接口,需要注意这些,看你做到了几项
本文介绍了设计API接口时需注意的关键点,包括数字签名、敏感数据加密与脱敏、限流、参数校验、统一返回与异常处理、请求日志记录、幂等设计、数据量限制、异步处理、参数定义、完整文档及开发者对接SDK等内容,旨在帮助开发者设计出安全、稳定、易维护的API接口。
83 6
开发一份API接口,需要注意这些,看你做到了几项
|
25天前
|
JSON 安全 API
如何使用Python开发API接口?
在现代软件开发中,API(应用程序编程接口)用于不同软件组件之间的通信和数据交换,实现系统互操作性。Python因其简单易用和强大功能,成为开发API的热门选择。本文详细介绍了Python开发API的基础知识、优势、实现方式(如Flask和Django框架)、实战示例及注意事项,帮助读者掌握高效、安全的API开发技巧。
57 3
如何使用Python开发API接口?
|
14天前
|
缓存 前端开发 API
深入浅出:后端开发中的RESTful API设计原则
【10月更文挑战第43天】在数字化浪潮中,后端开发如同搭建梦想的脚手架,而RESTful API则是连接梦想与现实的桥梁。本文将带你领略API设计的哲学之美,探索如何通过简洁明了的设计,提升开发效率与用户体验。从资源定位到接口约束,从状态转换到性能优化,我们将一步步构建高效、易用、可维护的后端服务。无论你是初涉后端的新手,还是寻求进阶的开发者,这篇文章都将为你的开发之路提供指引。让我们一起走进RESTful API的世界,解锁后端开发的新篇章。
|
21天前
|
存储 SQL API
探索后端开发:构建高效API与数据库交互
【10月更文挑战第36天】在数字化时代,后端开发是连接用户界面和数据存储的桥梁。本文深入探讨如何设计高效的API以及如何实现API与数据库之间的无缝交互,确保数据的一致性和高性能。我们将从基础概念出发,逐步深入到实战技巧,为读者提供一个清晰的后端开发路线图。
|
20天前
|
JSON 前端开发 API
后端开发中的API设计与文档编写指南####
本文探讨了后端开发中API设计的重要性,并详细阐述了如何编写高效、可维护的API接口。通过实际案例分析,文章强调了清晰的API设计对于前后端分离项目的关键作用,以及良好的文档习惯如何促进团队协作和提升开发效率。 ####
|
18天前
|
JSON API 数据格式
如何使用Python开发1688商品详情API接口?
本文介绍了如何使用Python开发1688商品详情API接口,获取商品的标题、价格、销量和评价等详细信息。主要内容包括注册1688开放平台账号、安装必要Python模块、了解API接口、生成签名、编写Python代码、解析返回数据以及错误处理和日志记录。通过这些步骤,开发者可以轻松地集成1688商品数据到自己的应用中。
30 1
|
21天前
|
监控 搜索推荐 安全
探究亚马逊详情API接口:开发与应用
在数字化时代,亚马逊作为全球领先的电商平台,为商家和消费者提供了丰富的商品信息和便捷的购物体验。本文深入探讨了亚马逊详情API接口的获取与运用,帮助开发者和商家实时监控商品数据、分析市场趋势、优化价格策略、分析竞争对手、构建推荐系统及自动化营销工具,从而在竞争中占据优势。文章还提供了Python调用示例和注意事项,确保API使用的安全与高效。
47 3
|
25天前
|
缓存 监控 Java
如何运用JAVA开发API接口?
本文详细介绍了如何使用Java开发API接口,涵盖创建、实现、测试和部署接口的关键步骤。同时,讨论了接口的安全性设计和设计原则,帮助开发者构建高效、安全、易于维护的API接口。
64 4