|
|
|
package com.fr.io;
|
|
|
|
|
|
|
|
import com.fr.base.operator.common.CommonOperator;
|
|
|
|
import com.fr.chart.activator.ChartBaseActivator;
|
|
|
|
import com.fr.cluster.engine.activator.standalone.StandaloneModeActivator;
|
|
|
|
import com.fr.config.activator.BaseDBActivator;
|
|
|
|
import com.fr.config.activator.ConfigurationActivator;
|
|
|
|
import com.fr.env.operator.CommonOperatorImpl;
|
|
|
|
import com.fr.general.I18nResource;
|
|
|
|
import com.fr.health.activator.ModuleHealActivator;
|
|
|
|
import com.fr.io.exporter.CSVExporter;
|
|
|
|
import com.fr.io.exporter.EmbeddedTableDataExporter;
|
|
|
|
import com.fr.io.exporter.ExcelExporter;
|
|
|
|
import com.fr.io.exporter.ImageExporter;
|
|
|
|
import com.fr.io.exporter.PDFExporter;
|
|
|
|
import com.fr.io.exporter.SVGExporter;
|
|
|
|
import com.fr.io.exporter.TextExporter;
|
|
|
|
import com.fr.io.exporter.WordExporter;
|
|
|
|
import com.fr.io.exporter.excel.stream.StreamExcel2007Exporter;
|
|
|
|
import com.fr.main.impl.WorkBook;
|
|
|
|
import com.fr.module.tool.ActivatorToolBox;
|
|
|
|
import com.fr.report.ReportActivator;
|
|
|
|
import com.fr.report.RestrictionActivator;
|
|
|
|
import com.fr.report.module.ReportBaseActivator;
|
|
|
|
import com.fr.stable.WriteActor;
|
|
|
|
import com.fr.store.StateServiceActivator;
|
|
|
|
import com.fr.workspace.simple.SimpleWork;
|
|
|
|
|
|
|
|
import java.io.FileOutputStream;
|
|
|
|
import java.util.HashMap;
|
|
|
|
import java.util.Map;
|
|
|
|
|
|
|
|
|
|
|
|
public class ExportApi {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 这段静态代码块仅在main函数测试时使用,
|
|
|
|
* 实际生产环境中一般使用web容器,集成帆软后帆软服务会自动启动,不再需要下面的静态代码,直接写导出的业务逻辑即可。
|
|
|
|
* web集成注意事项:
|
|
|
|
* 1、集成环境需要依赖【当前使用jdk对应版本的】tools.jar,一般从jdk中直接复制即可;
|
|
|
|
* 2、帆软服务自动启动成功后,使用的工作目录自动识别为web应用下的WEB-INF目录,所以需要把下面代码中envpath指向的工作目录拷贝到集成环境下web应用的WEB-INF目录,
|
|
|
|
* 这样才能沿用原先帆软的配置及模板。如果集群环境,会自动使用文件服务器的模板。
|
|
|
|
* 3、可以访问集成环境的地址: ip:port/应用名/decision 。如果能成功访问且不需要初始化配置则代表帆软服务启动成功
|
|
|
|
*/
|
|
|
|
static {
|
|
|
|
Module preModule = ModuleContext.getModule(ReportActivator.class);
|
|
|
|
boolean running = preModule != null && preModule.isRunning();
|
|
|
|
if (!running) {
|
|
|
|
/**定义报表运行环境,用于执行报表*/
|
|
|
|
com.fr.module.Module module = ActivatorToolBox.simpleLink(
|
|
|
|
new BaseDBActivator(),
|
|
|
|
new ConfigurationActivator(),
|
|
|
|
new ResourceRepositoryActivator(),
|
|
|
|
new StandaloneModeActivator(),
|
|
|
|
new ModuleHealActivator(),
|
|
|
|
//2020.4.26jar包之前的版本,替换成StateServerActivator()
|
|
|
|
new StateServiceActivator(),
|
|
|
|
new ReportBaseActivator(),
|
|
|
|
new RestrictionActivator(),
|
|
|
|
new ReportActivator(),
|
|
|
|
new ChartBaseActivator());
|
|
|
|
SimpleWork.supply(CommonOperator.class, new CommonOperatorImpl());
|
|
|
|
//定义工程路径
|
|
|
|
String envpath = "D:\\FineReport_11.0\\webapps\\webroot\\WEB-INF\\";
|
|
|
|
SimpleWork.checkIn(envpath);
|
|
|
|
I18nResource.getInstance();
|
|
|
|
module.start();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public static void main(String[] args) {
|
|
|
|
/**输出模板*/
|
|
|
|
try {
|
|
|
|
// 定义输出的模板路径,以reportlets为根目录
|
|
|
|
WorkBook workbook = (WorkBook) TemplateWorkBookIO.readTemplateWorkBook("GettingStarted.cpt");
|
|
|
|
// 设置传入的参数
|
|
|
|
Map parameterMap = new HashMap();
|
|
|
|
parameterMap.put("地区","华东");
|
|
|
|
|
|
|
|
// 定义输出流
|
|
|
|
FileOutputStream outputStream;
|
|
|
|
String outputUrl="F:\\io\\WorkBook\\";
|
|
|
|
|
|
|
|
/**将模板工作薄导出为内置数据集模板文件*/
|
|
|
|
outputStream = new FileOutputStream(new java.io.File(outputUrl+"EmbExport.cpt"));
|
|
|
|
EmbeddedTableDataExporter templateExporter = new EmbeddedTableDataExporter();
|
|
|
|
templateExporter.export(outputStream, workbook);
|
|
|
|
|
|
|
|
/**将模板工作薄导出为模板文件*/
|
|
|
|
outputStream = new FileOutputStream(new java.io.File(outputUrl+"TmpExport.cpt"));
|
|
|
|
((WorkBook) workbook).export(outputStream);
|
|
|
|
|
|
|
|
/**将结果工作薄导出为2003Excel文件*/
|
|
|
|
outputStream = new FileOutputStream(new java.io.File(outputUrl+"ExcelExport2003.xls"));
|
|
|
|
ExcelExporter ExcelExport = new ExcelExporter();
|
|
|
|
ExcelExport.setVersion(true);
|
|
|
|
ExcelExport.export(outputStream, workbook.execute(parameterMap, new WriteActor()));
|
|
|
|
|
|
|
|
/**将结果工作薄导出为2007Excel文件*/
|
|
|
|
outputStream = new FileOutputStream(new java.io.File(outputUrl+"ExcelExport2007.xlsx"));
|
|
|
|
StreamExcel2007Exporter ExcelExport1 = new StreamExcel2007Exporter();
|
|
|
|
ExcelExport1.export(outputStream, workbook.execute(parameterMap, new WriteActor()));
|
|
|
|
|
|
|
|
/**将结果工作薄导出为Word文件*/
|
|
|
|
outputStream = new FileOutputStream(new java.io.File(outputUrl+"WordExport.doc"));
|
|
|
|
WordExporter WordExport = new WordExporter();
|
|
|
|
WordExport.export(outputStream, workbook.execute(parameterMap, new WriteActor()));
|
|
|
|
|
|
|
|
/**将结果工作薄导出为Pdf文件*/
|
|
|
|
outputStream = new FileOutputStream(new java.io.File(outputUrl+"PdfExport.pdf"));
|
|
|
|
PDFExporter PdfExport = new PDFExporter();
|
|
|
|
PdfExport.export(outputStream, workbook.execute(parameterMap, new WriteActor()));
|
|
|
|
|
|
|
|
/**将结果工作薄导出为Txt文件(txt文件本身不支持表格、图表等,被导出模板一般为明细表)*/
|
|
|
|
outputStream = new FileOutputStream(new java.io.File(outputUrl+"TxtExport.txt"));
|
|
|
|
TextExporter TxtExport = new TextExporter();
|
|
|
|
TxtExport.export(outputStream, workbook.execute(parameterMap, new WriteActor()));
|
|
|
|
|
|
|
|
/**将结果工作薄导出为Csv文件*/
|
|
|
|
outputStream = new FileOutputStream(new java.io.File(outputUrl+"CsvExport.csv"));
|
|
|
|
CSVExporter CsvExport = new CSVExporter();
|
|
|
|
CsvExport.export(outputStream, workbook.execute(parameterMap, new WriteActor()));
|
|
|
|
|
|
|
|
/**将结果工作薄导出为SVG文件*/
|
|
|
|
outputStream = new FileOutputStream(new java.io.File(outputUrl+"SvgExport.svg"));
|
|
|
|
SVGExporter SvgExport = new SVGExporter();
|
|
|
|
SvgExport.export(outputStream, workbook.execute(parameterMap, new WriteActor()));
|
|
|
|
|
|
|
|
/**将结果工作薄导出为image文件*/
|
|
|
|
outputStream = new FileOutputStream(new java.io.File(outputUrl+"PngExport.png"));
|
|
|
|
ImageExporter ImageExport = new ImageExporter();
|
|
|
|
ImageExport.export(outputStream, workbook.execute(parameterMap, new WriteActor()));
|
|
|
|
|
|
|
|
outputStream.close();
|
|
|
|
} catch (Exception e) {
|
|
|
|
e.printStackTrace();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|