报表开发导出各种格式文件的API
来源:互联网 发布:淘宝总销售额查询 编辑:程序博客网 时间:2024/05/16 14:09
文件输出的多样性,准确性和稳定性对于我们常用的报表软件来说很重要。报表的输入是指从报表的模板文件(XML格式的)创建WorkBook对象,输出则指将报表保存为各种格式文件,比如Pdf、Excel、Word这种常见的文件格式,比如FineReport还支持cpt、Svg、Csv、Image(包含png、 jpg、gif、 bmp、wbmp)等多种文件格式。
因为常常会碰到报表的开发工作,这里总结了几种格式文件导出的API。
1、导出成内置数据集模板
导出成内置数据集模板,就是将原模板的数据源根据参数条件查询出结果并转为内置数据集,然后把模板导出,不需要对原模板进行计算(数据列扩展、公式计算等)。
// 将未执行模板工作薄导出为内置数据集模板outputStream = new FileOutputStream(new File("E:\\EmbExport.cpt"));EmbeddedTableDataExporter templateExporter = new EmbeddedTableDataExporter();templateExporter.export(outputStream, workbook);
2、导出模板文件
我们可以将原模板通过程序编辑后再次导出为模板文件,或者将某一路径下的模板保存至另一路径下。
// 将模板工作薄导出模板文件,在导出前您可以编辑导入的模板工作薄,可参考报表调用章节outputStream = new FileOutputStream(new File("E:\\TmpExport.cpt"));((WorkBook) workbook).export(outputStream);
3、导出Excel文件
模板工作薄WorkBook执行后为结果工作薄ResultWorkBook,我们可以把计算后的结果导出成Excel文件。
// 将结果工作薄导出为Excel文件outputStream = new FileOutputStream(new File("E:\\ExcelExport.xls"));ExcelExporter ExcelExport = new ExcelExporter();ExcelExport.export(outputStream, workbook.execute(parameterMap,new WriteActor()));
4、导出Word文件
// 将结果工作薄导出为Word文件outputStream = new FileOutputStream(new File("E:\\WordExport.doc"));WordExporter WordExport = new WordExporter();WordExport.export(outputStream, workbook.execute(parameterMap,new WriteActor()));
5、导出Pdf文件
// 将结果工作薄导出为Pdf文件 outputStream = new FileOutputStream(newFile("E:\\PdfExport.pdf")); PDFExporter PdfExport = newPDFExporter(); PdfExport.export(outputStream,workbook.execute(parameterMap,new WriteActor()));
6、导出Txt文件
// 将结果工作薄导出为Txt文件(txt文件本身不支持表格、图表等,被导出模板一般为明细表)outputStream = new FileOutputStream(new File("E:\\TxtExport.txt"));
7、导出Csv文件
// 将结果工作薄导出为Csv文件outputStream = new FileOutputStream(new File("E:\\CsvExport.csv"));CSVExporter CsvExport = new CSVExporter();CsvExport.export(outputStream, workbook.execute(parameterMap,new WriteActor()));
8、导出Svg文件
//将结果工作薄导出为SVG文件 outputStream = new FileOutputStream(new File("D:\\SvgExport.svg")); SVGExporter SvgExport = new SVGExporter(); SvgExport.export(outputStream, workbook.execute(parameterMap,new WriteActor()));
9、导出Image文件
//将结果工作薄导出为image文件 outputStream = new FileOutputStream(new File("D:\\PngExport.png")); ImageExporter ImageExport = new ImageExporter(); ImageExport.export(outputStream, workbook.execute(parameterMap,new WriteActor()));
10、释放进程
通过导出API在后台导出excel等文件,会产生很多进程,通过下面的方案释放进程。在导出完成之后添加下面代码:
outputStream.close();ModuleContext.stopModules();
例如,一个完整的可执行代码:
package com.fr.io; import java.io.File; import java.io.FileOutputStream; import com.fr.base.FRContext; import com.fr.general.ModuleContext;import com.fr.base.Parameter;import com.fr.dav.LocalEnv;import com.fr.io.exporter.CSVExporter;import com.fr.io.exporter.EmbeddedTableDataExporter;import com.fr.io.exporter.Excel2007Exporter;import com.fr.io.exporter.ExcelExporter;import com.fr.io.exporter.PDFExporter;import com.fr.io.exporter.TextExporter;import com.fr.io.exporter.WordExporter;import com.fr.io.exporter.SVGExporter;import com.fr.io.exporter.ImageExporter;import com.fr.main.impl.WorkBook;import com.fr.main.workbook.ResultWorkBook;import com.fr.report.module.EngineModule;import com.fr.stable.WriteActor; public class ExportApi { public static void main(String[] args) { // 定义报表运行环境,才能执行报表 String envpath = "D:\\FineReport_8.0\\WebReport\\WEB-INF"; FRContext.setCurrentEnv(new LocalEnv(envpath)); ModuleContext.startModule(EngineModule.class.getName()); ResultWorkBook rworkbook = null; try { // 未执行模板工作薄 WorkBook workbook = (WorkBook) TemplateWorkBookIO .readTemplateWorkBook(FRContext.getCurrentEnv(), "\\doc\\Primary\\Parameter\\Parameter.cpt"); // 获取报表参数并设置值,导出内置数据集时数据集会根据参数值查询出结果从而转为内置数据集 Parameter[] parameters = workbook.getParameters(); parameters[0].setValue("华东"); // 定义parametermap用于执行报表,将执行后的结果工作薄保存为rworkBook java.util.Map parameterMap = new java.util.HashMap(); for (int i = 0; i < parameters.length; i++) { parameterMap.put(parameters[i].getName(), parameters[i] .getValue()); } // 定义输出流 FileOutputStream outputStream; // 将未执行模板工作薄导出为内置数据集模板 outputStream = new FileOutputStream(new File("D:\\EmbExport.cpt")); EmbeddedTableDataExporter templateExporter = new EmbeddedTableDataExporter(); templateExporter.export(outputStream, workbook); // 将模板工作薄导出模板文件,在导出前您可以编辑导入的模板工作薄,可参考报表调用章节 outputStream = new FileOutputStream(new File("D:\\TmpExport.cpt")); ((WorkBook) workbook).export(outputStream); // 将结果工作薄导出为2003Excel文件 outputStream = new FileOutputStream(new File("D:\\ExcelExport.xls")); ExcelExporter ExcelExport = new ExcelExporter(); ExcelExport.export(outputStream, workbook.execute(parameterMap,new WriteActor())); // 将结果工作薄导出为Word文件 outputStream = new FileOutputStream(new File("D:\\WordExport.doc")); WordExporter WordExport = new WordExporter(); WordExport.export(outputStream, workbook.execute(parameterMap,new WriteActor())); // 将结果工作薄导出为Pdf文件 outputStream = new FileOutputStream(new File("D:\\PdfExport.pdf")); PDFExporter PdfExport = new PDFExporter(); PdfExport.export(outputStream, workbook.execute(parameterMap,new WriteActor())); // 将结果工作薄导出为Txt文件(txt文件本身不支持表格、图表等,被导出模板一般为明细表) outputStream = new FileOutputStream(new File("D:\\TxtExport.txt")); TextExporter TxtExport = new TextExporter(); TxtExport.export(outputStream, workbook.execute(parameterMap,new WriteActor())); // 将结果工作薄导出为Csv文件 outputStream = new FileOutputStream(new File("D:\\CsvExport.csv")); CSVExporter CsvExport = new CSVExporter(); CsvExport.export(outputStream, workbook.execute(parameterMap,new WriteActor())); //将结果工作薄导出为SVG文件 outputStream = new FileOutputStream(new File("D:\\SvgExport.svg")); SVGExporter SvgExport = new SVGExporter(); SvgExport.export(outputStream, workbook.execute(parameterMap,new WriteActor())); //将结果工作薄导出为image文件 outputStream = new FileOutputStream(new File("D:\\PngExport.png")); ImageExporter ImageExport = new ImageExporter(); ImageExport.export(outputStream, workbook.execute(parameterMap,new WriteActor())); outputStream.close(); ModuleContext.stopModules(); } catch (Exception e) { e.printStackTrace(); } } }
编译运行该代码后,就会在E盘下生成不同格式的文件,这样就导出成功了。
1 0
- 报表开发导出各种格式文件的API
- Access 导出各种格式文件
- Access 导出各种格式文件
- sqlserver的用sql语句导入导出各种格式文件
- 报表导出为CVS,pdf格式文件格式
- 报表导出数据成.csv格式文件
- 各种文档格式文件预览的实现
- C#实现各种格式文件的复制
- android各种格式文件的打开(代码)
- DataGrid内容导出标准的Excel格式文件
- 水晶报表的导出
- Excel报表的导出
- 导出报表的代码
- 报表的导出
- 导出报表的实现
- [水晶报表]导出各种报表到指定目录
- 业务开发中动态导出报表的一些思路
- 润乾报表Api导出word只读
- gcc/g++
- SYSAUX Tablespace Grows Quite Fast Due to Apply Spilling (Doc ID 556183.1)
- 【Android基础知识】Android五大布局
- IntelliJ 使用笔记
- vijosP1282 佳佳的魔法照片
- 报表开发导出各种格式文件的API
- 高效定时器的实现方式
- Andoid自动判断输入是电话,网址或者Email的方法----Linkify的应用!
- GetProcessMemoryInfo
- beanUtils 使用
- pkg-config的使用
- Android ListView优化篇
- 福兮祸兮?
- 代理模式-延迟加载场景