Java报表工具FineReport导出EXCEL的四种API

简介:

在实际的应用中会经常需要将数据导出成excel,导出的方式除原样导出还有分页导出、分页分sheet导出和大数据量导出。对于excel 2003版,由于限制了每个sheet的最大行数和列数,大数据量导出时会默认时分多个sheet,而excel2007不会出现这样的问题。这些导出方式在JAVA程序中分别有不同的接口来实现:

  1、原样导出

原样导出就是不预览直接导出excel

其程序接口代码如下:

1
2
3
4
  outputStream =  new  FileOutputStream( new  File( "E:\\ExcelExport.xls" ));  
  ExcelExporter excel =  new  ExcelExporter();  
  //导出2007版 outputStream = new FileOutputStream(new File("E:\\ExcelExport.xlsx"));  excel Excel2007Exporter excel = new Excel2007Exporter();
  excel.export(outputStream, rworkbook);

 效果图:



2分页导出

分页导出,如果报表模版是分页的,会按照分页的结果形式导出,重复的标题等也会重复。

其程序接口代码如下:

1
2
3
4
  outputStream =  new  FileOutputStream( new  File( "E:\\PageExcelExport.xls" ));
  PageExcelExporter page =  new  PageExcelExporter(ReportUtils.getPaperSettingListFromWorkBook(rworkbook));
//导出2007版 outputStream = new FileOutputStream(new File("E:\\PageExcelExport.xlsx")); excel  PageExcel2007Exporter page = new PageExcel2007Exporter(ReportUtils.getPaperSettingListFromWorkBook(rworkbook));
  page.export(outputStream, rworkbook);

  

效果图:



 3、分页分sheet导出

分页分Sheet导出时报表结果的每一页为一个Sheet保存在Excel文件中

其代码如下:

1
2
3
4
  outputStream =  new  FileOutputStream( new  File( "E:\\PageSheetExcelExport.xls" ));
  PageToSheetExcelExporter sheet =  new  PageToSheetExcelExporter(ReportUtils.getPaperSettingListFromWorkBook(rworkbook));
  //导出2007版outputStream = new FileOutputStream(new File("E:\\PageSheetExcelExport.xlsx")); excel PageToSheetExcel2007Exporter sheet = new PageToSheetExcel2007Exporter(ReportUtils.getPaperSettingListFromWorkBook(rworkbook));
  sheet.export(outputStream, rworkbook);


 

效果图:



4、大数据量导出

这是比较常见的,例如以50000行为一个excel文件

其代码如下:

1
2
3
4
  outputStream =  new  FileOutputStream( new  File( "E:\\LargeExcelExport.zip" ));
  LargeDataPageExcelExporter large =  new  LargeDataPageExcelExporter(ReportUtils.getPaperSettingListFromWorkBook(rworkbook),  true );
  //导出2007版outputStream = new FileOutputStream(new File("E:\\LargeExcelExport.xlsx")); excel LargeDataPageExcel2007Exporter large = new LargeDataPageExcel2007Exporter(ReportUtils.getPaperSettingListFromWorkBook(rworkbook), true);
  large.export(outputStream, rworkbook);


对于大数据量导出报表时,可能会出现如下两种情况:

  • 导出成功,数据会显示在多个Sheet中;

  • Excel内容无效。出现如上情况的原因主要有两点:

  • 没有启用行式引擎的大数据量报表导出

在没有启用行式引擎的情况下,也会出现两种情况:服务器可以承受的情况下导出成功,服务器无法承受的情况下导出失败,下面我们分别看下其结果:

4.1.1 服务器承受范围内

可以承受的范围是:数据量大,超过了EXCEL的最大行数但不是非常非常大,比如10万条,且数据不复杂,在内存足够且网络没有断的情况下可以正常导出。导出时,超出Excel最大行或列的数据会在下一个Sheet中显示。但是Excel的行数和列数是有限制的,如Excel2003其行数最大限制为65536行,列数最大限制为256列。

4.1.2 服务器无法承受

无法承受的范围是主要是数据量大,且非常大,比如几十万几百万甚至更多,可能因为内存等的限制而出现导出失败。而导出的结果时,打开导出失败的Excel,其内容是无效的。

对于这两种导出结果,其主要原因在于数据量与数据复杂程度(列数)究竟有多大,在没有用行引擎的情况下就会有一个临界点,低于临界点的时候可以导出成功即导出的内容有多个sheet,否则导出失败,内容无效。所以,对于大数据量报表,通常使用行式引擎来展现,这种情况下,导出Excel始终成功。在启用行式引擎的大数据量报表导出Excel时,是将其分成多个.xls文件,且是以一个压缩包文件的格式传输到客户端的。

4.2 启用行式引擎的大数据量报表导出

对于大数据量报表,通常使用行式引擎来展现,这种情况下,导出Excel始终成功。因为启用行式引擎的大数据量报表导出Excel时,是将其分成多个.xls文件,且是以一个压缩包文件的格式传输到客户端的。

 

比如,大数据量报表有100w行数据,设置行式引擎,每页显示30行。导出的结果会是41Excel,前40Excel每个24990行,最后一个Excel400行,41Excel压缩为zip包传到客户端下载。



本文转自 雄霸天下啦 51CTO博客,原文链接:http://blog.51cto.com/10549520/1751277,如需转载请自行联系原作者
相关实践学习
简单用户画像分析
本场景主要介绍基于海量日志数据进行简单用户画像分析为背景,如何通过使用DataWorks完成数据采集 、加工数据、配置数据质量监控和数据可视化展现等任务。
SaaS 模式云数据仓库必修课
本课程由阿里云开发者社区和阿里云大数据团队共同出品,是SaaS模式云原生数据仓库领导者MaxCompute核心课程。本课程由阿里云资深产品和技术专家们从概念到方法,从场景到实践,体系化的将阿里巴巴飞天大数据平台10多年的经过验证的方法与实践深入浅出的讲给开发者们。帮助大数据开发者快速了解并掌握SaaS模式的云原生的数据仓库,助力开发者学习了解先进的技术栈,并能在实际业务中敏捷的进行大数据分析,赋能企业业务。 通过本课程可以了解SaaS模式云原生数据仓库领导者MaxCompute核心功能及典型适用场景,可应用MaxCompute实现数仓搭建,快速进行大数据分析。适合大数据工程师、大数据分析师 大量数据需要处理、存储和管理,需要搭建数据仓库?学它! 没有足够人员和经验来运维大数据平台,不想自建IDC买机器,需要免运维的大数据平台?会SQL就等于会大数据?学它! 想知道大数据用得对不对,想用更少的钱得到持续演进的数仓能力?获得极致弹性的计算资源和更好的性能,以及持续保护数据安全的生产环境?学它! 想要获得灵活的分析能力,快速洞察数据规律特征?想要兼得数据湖的灵活性与数据仓库的成长性?学它! 出品人:阿里云大数据产品及研发团队专家 产品 MaxCompute 官网 https://www.aliyun.com/product/odps 
相关文章
|
5月前
|
API 对象存储
postman导出api文档
postman导出api文档
56 0
|
4月前
|
API
uniapp上传文件api如何使用
uniapp上传文件api如何使用
138 3
|
JSON Java API
一款适合IT团队的在线API文档、技术文档工具-showdoc介绍
为大家推荐一款适合IT团队的在线API文档、技术文档工具,有免费开源和在线托管的版本。可以直接使用官网搭建好的地址,也可以在自己的服务器上搭建。
一款适合IT团队的在线API文档、技术文档工具-showdoc介绍
|
5月前
|
监控 网络协议 API
开发常用的 3种 API 监控报告
API 监控报告是一种监测 API 异常的工具。在 API 管理中,查看 API 异常监控的监控报告,是 Eolink Apikit 常用的功能。Eolink Apikit 的监控报告有 3种:单接口监控报告、流程监控报告、项目监控报告
39 0
|
5月前
|
安全 API 数据库
一款支持API文档编辑功能的WIKI文档管理系统
zyplayer-doc是一款现代化的适合团队和个人使用的WIKI文档管理工具,同时还包含数据库文档、Api接口文档
617 0
|
Java API Maven
接口文档:第二章:使用Swagger接口的文档在线自动生成
接口文档:第二章:使用Swagger接口的文档在线自动生成
181 0
接口文档:第二章:使用Swagger接口的文档在线自动生成
|
测试技术 API 数据安全/隐私保护
5分钟打造好用好看API文档
对接第三方开放平台文档的时候,左手刷着接口文档看API,右手操作着接口调试工具 🧱
5分钟打造好用好看API文档
|
JSON 前端开发 JavaScript
这个API文档,太拽了吧!
在当前主流的前端后端分离模式开发下,拥有一个接口文档并且是好用的接口文档是很有必要的一个东西。
这个API文档,太拽了吧!
|
Java 数据处理