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

本文涉及的产品
云原生大数据计算服务MaxCompute,500CU*H 100GB 3个月
简介:
+关注继续查看

在实际的应用中会经常需要将数据导出成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/1751281,如需转载请自行联系原作者

相关实践学习
简单用户画像分析
本场景主要介绍基于海量日志数据进行简单用户画像分析为背景,如何通过使用DataWorks完成数据采集 、加工数据、配置数据质量监控和数据可视化展现等任务。
SaaS 模式云数据仓库必修课
本课程由阿里云开发者社区和阿里云大数据团队共同出品,是SaaS模式云原生数据仓库领导者MaxCompute核心课程。本课程由阿里云资深产品和技术专家们从概念到方法,从场景到实践,体系化的将阿里巴巴飞天大数据平台10多年的经过验证的方法与实践深入浅出的讲给开发者们。帮助大数据开发者快速了解并掌握SaaS模式的云原生的数据仓库,助力开发者学习了解先进的技术栈,并能在实际业务中敏捷的进行大数据分析,赋能企业业务。 通过本课程可以了解SaaS模式云原生数据仓库领导者MaxCompute核心功能及典型适用场景,可应用MaxCompute实现数仓搭建,快速进行大数据分析。适合大数据工程师、大数据分析师 大量数据需要处理、存储和管理,需要搭建数据仓库?学它! 没有足够人员和经验来运维大数据平台,不想自建IDC买机器,需要免运维的大数据平台?会SQL就等于会大数据?学它! 想知道大数据用得对不对,想用更少的钱得到持续演进的数仓能力?获得极致弹性的计算资源和更好的性能,以及持续保护数据安全的生产环境?学它! 想要获得灵活的分析能力,快速洞察数据规律特征?想要兼得数据湖的灵活性与数据仓库的成长性?学它! 出品人:阿里云大数据产品及研发团队专家 产品 MaxCompute 官网 https://www.aliyun.com/product/odps 
相关文章
|
1天前
|
JSON API 数据格式
如何获取虾皮shopee根据ID取商品详情 API接口
以下是一篇关于如何使用Shopee API接口根据商品ID获取商品详情的5000字文章,包括API接口的基本信息、请求方法、请求参数、返回数据等,以及使用Python进行API调用的示例代码。
|
1天前
|
JSON API 开发者
如何获取淘宝/天猫删除购物车商品 API 接口
如何获取淘宝/天猫删除购物车商品 API 接口 一、API 概述 淘宝/天猫提供了删除购物车商品 API 接口,允许开发者通过编程方式删除用户购物车中的商品。这个 API 接口可以帮助开发者更好地管理用户的购物车,例如在用户取消订单或者调整购物车商品数量时,可以调用此 API 接口删除相应的商品
|
1天前
|
JSON API 开发者
淘宝获取购物车的商品列表 API接口
淘宝提供了获取购物车商品列表 API 接口,允许开发者通过编程方式获取用户购物车中的商品列表。这个 API 接口可以帮助开发者更好地了解用户在购物车中添加了哪些商品,以及每个商品的基本信息,例如商品 ID、名称、价格、数量等。
|
1天前
|
Java API
POI (excel) - API使用与参考
POI (excel) - API使用与参考
11 0
|
Java API
使用java api 创建excel内容并发送邮件
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_26654727/article/details/83473968 文章目...
2812 0
|
Web App开发 JavaScript 前端开发
web在线编辑word,excel,pdf插件-----WebOffice 文档控件API
目    录       一、工作原理...5 1.1         开发流程...5 1.2         WEB页面调用控件:.6 二、接口说明...7 2.1         接口...7 2.1.1     AboutBox.7 2.1.2     AcceptAllRevisions.7 2.1.3     CloseDoc.7 2.1.4  
9180 0
|
API C# Windows
如何通过WPS 2013 API 将Office(Word、Excel和PPT)文件转PDF文件
原文:如何通过WPS 2013 API 将Office(Word、Excel和PPT)文件转PDF文件 1. 描述   PDF 文件是一种便携文件格式,是由Adobe公司所开发的独特的跨平台文件格式。
2538 0
|
Java API 索引
Java操作Excel文件基础--Java Excel API
        Java Excel API是一个成熟的、开源的Java API,主页地址:http://jexcelapi.sourceforge.net/,通过它开发人员可以动态地读取、写入或者修改Excel文件。
1319 0
相关产品
云迁移中心
推荐文章
更多