报表开发导出各种格式文件的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,如需转载请自行联系原作者

相关文章
|
1月前
|
缓存 安全 测试技术
构建高效的RESTful API:后端开发的实践指南
【2月更文挑战第17天】在数字化转型的浪潮中,RESTful API已成为连接不同软件组件、实现数据交互的核心桥梁。本文将深入探讨如何构建一个高效、可扩展且安全的RESTful API,涉及设计原则、开发流程以及性能优化等关键方面。我们将透过实际案例,展示如何在保证简洁性和灵活性的同时,满足日益增长的业务需求和技术挑战。
|
1月前
|
API
uni-app 146朋友圈列表api开发
uni-app 146朋友圈列表api开发
16 0
|
13天前
|
前端开发 Java API
构建RESTful API:Java中的RESTful服务开发
【4月更文挑战第3天】本文介绍了在Java环境中构建RESTful API的重要性及方法。遵循REST原则,利用HTTP方法处理资源,实现CRUD操作。在Java中,常用框架如Spring MVC简化了RESTful服务开发,包括定义资源、设计表示层、实现CRUD、考虑安全性、文档和测试。通过Spring MVC示例展示了创建RESTful服务的步骤,强调了其在现代Web服务开发中的关键角色,有助于提升互操作性和用户体验。
构建RESTful API:Java中的RESTful服务开发
|
22天前
|
Java 数据库连接 API
Java 学习路线:基础知识、数据类型、条件语句、函数、循环、异常处理、数据结构、面向对象编程、包、文件和 API
Java 是一种广泛使用的、面向对象的编程语言,始于1995年,以其跨平台性、安全性和可靠性著称,应用于从移动设备到数据中心的各种场景。基础概念包括变量(如局部、实例和静态变量)、数据类型(原始和非原始)、条件语句(if、else、switch等)、函数、循环、异常处理、数据结构(如数组、链表)和面向对象编程(类、接口、继承等)。深入学习还包括包、内存管理、集合框架、序列化、网络套接字、泛型、流、JVM、垃圾回收和线程。构建工具如Gradle、Maven和Ant简化了开发流程,Web框架如Spring和Spring Boot支持Web应用开发。ORM工具如JPA、Hibernate处理对象与数
88 3
|
26天前
|
缓存 前端开发 API
构建高效可扩展的RESTful API:后端开发的最佳实践
【2月更文挑战第30天】 在现代Web应用和服务端架构中,RESTful API已成为连接前端与后端、实现服务间通信的重要接口。本文将探讨构建一个高效且可扩展的RESTful API的关键步骤和最佳实践,包括设计原则、性能优化、安全性考虑以及错误处理机制。通过这些实践,开发者可以确保API的健壮性、易用性和未来的可维护性。
|
1月前
|
分布式计算 DataWorks 大数据
DataWorks常见问题之使用API删除之前的部署文件失败如何解决
DataWorks是阿里云提供的一站式大数据开发与管理平台,支持数据集成、数据开发、数据治理等功能;在本汇总中,我们梳理了DataWorks产品在使用过程中经常遇到的问题及解答,以助用户在数据处理和分析工作中提高效率,降低难度。
|
1月前
|
API
uni-app 147我的朋友圈列表api开发
uni-app 147我的朋友圈列表api开发
12 0
|
1月前
|
API
uni-app 145评论朋友圈api开发(二)
uni-app 145评论朋友圈api开发(二)
14 0
|
1月前
|
API
uni-app 144评论朋友圈api开发(一)
uni-app 144评论朋友圈api开发(一)
15 1