package zxc.util.ieport;
import java.util.List;
import java.util.Map;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Pointcut;
import org.springframework.util.CollectionUtils;
import zxc.exceptions.BaseRuntimeException;
import zxc.model.support.BaseBean;
import zxc.model.support.FileBaseBean;
import zxc.model.support.IeudBean;
import zxc.util.ieport.poi.POIExcelFactory;
import zxc.utils.Page;
/**
* 在测试本服务时出现了不少问题,切点的定义总是不能找到目标方法.当前初的设想是这样的,因为底层有一个查询方法提供了一个较宽
* 的查询区域,其它一些较窄的方法可以调用它,那么我觉得将这个服务绑定到最底层的方法调用后这样就不必在每一个需要此服务的方法
* 前打NeedExprot,或者去写一个复杂切点表达式,但是测试了很长时间仍不能成功,表现出来的现象是,有个别方法可以,而大部分方法
* 不能被成功的绑定此服务,最后发现好象有这样一个规律,如果一个方法被本类中的其它方法调用,则被调用的方法将不会应用服务,具体是
* 不是这样我也不确定,其实我联想到事务的控制,这个事务控制服务是不是也这样一种情况呢?即最外层的方法会应用服务呢?因为这也与事务
* 表现有些相似,即具有某种服务的对象,如果它具有同种服务的方法调用,则内面的方法的服务就会被屏蔽掉,这个结论还需要进一步验证
*
*
* @author KHT
*
*/
@Aspect
public class ExportService {
public static final Integer DEFAULT_MAX_COUNT_ONE_TIME = 50;
public static final Integer DEFAULT_MAX_EXPORT_TIMES = 50;
public static final Integer EXCEL_SUPPORT_MAX_COUNT = 60000;
private Integer maxCountOneTime;
@SuppressWarnings("unused")
@Pointcut(value = "@annotation(zxc.util.ieport.NeedExport)")
private void needExport() {
}
//@AfterReturning(value = "needExport() && args(model,..)", returning = "rowset")
public void processExport(BaseBean model, List<Map<String, Object>> rowset) {
IeudBean ieudBean = ((FileBaseBean) model).getIeudBean();
ieudBean.setExportData(rowset);
POIExcelFactory.getFactory().processExcelExport((FileBaseBean) model);
}
public Integer getMaxCountOneTime() {
if (maxCountOneTime == null) {
maxCountOneTime = DEFAULT_MAX_COUNT_ONE_TIME;
}
return maxCountOneTime;
}
public void setMaxCountOneTime(Integer maxCountOneTime) {
this.maxCountOneTime = maxCountOneTime;
}
@Around("needExport()")
public Object processExport(ProceedingJoinPoint joinPoint) {
Object[] args = joinPoint.getArgs();
FileBaseBean model = (FileBaseBean) args[0];
IeudBean ieudBean = model.getIeudBean();
List<?> list = null;
try {
//需要导出
if (ieudBean.getExport() != null && ieudBean.getExport()) {
//这里返回的list没有太大的意义,为了节省内存空间,只返回了最后页的数据
list = exportData(joinPoint, args, model, ieudBean);
} else {
list = (List<?>) joinPoint.proceed(args);
}
} catch (Throwable e) {
throw new BaseRuntimeException("获取导入导出实体失败", e);
}
return list;
}
//此方法完全是处理导出
private List<?> exportData(ProceedingJoinPoint joinPoint, Object[] args, BaseBean model, IeudBean ieudBean) throws Throwable {
List<?> list = null;
//处理一次性导出
if (ieudBean.getOneTimeExport()) {
list = (List<?>) joinPoint.proceed(args);
ieudBean.setExportData(list);
POIExcelFactory.getFactory().processExcelExport((FileBaseBean) model);
System.err.println("一次性导出...");
} else {//处理分批导出
Integer maxCount = ieudBean.getMaxCountOneTime();
if (maxCount == null || maxCount <= 0) {
maxCount = this.getMaxCountOneTime();
}
if (model.getPage() == null) {
model.setPage(new Page());
}
model.getPage().setLimit(maxCount);
Integer maxTimes = EXCEL_SUPPORT_MAX_COUNT / maxCount;
Integer currentTimes = 0;
boolean isExit = false;
do {
model.getPage().setStart(currentTimes * maxCount);
currentTimes++;
System.err.println("分批导出:" + currentTimes);
list = (List<?>) joinPoint.proceed(args);
ieudBean.setExportData(list);
if (CollectionUtils.isEmpty(list) || list.size() < maxCount || currentTimes >= maxTimes) {
//设置已经导出完成的标记,以便完成导出的结束工作
ieudBean.setExportCompleted(true);
isExit = true;//退出循环
}
POIExcelFactory.getFactory().processExcelExport((FileBaseBean) model);
} while (!isExit);
}
return list;
}
}
分享到:
相关推荐
在这个场景中,"poi导出数据到excel里"指的是使用Apache POI库在Java项目中将数据写入Excel文件的过程。这个功能在数据分析、报表生成或者数据导出等场景中非常常见。以下是对Apache POI导出数据到Excel的详细解释:...
**使用Apache POI导出数据到Excel** Apache POI是一个流行的开源库,它允许程序员创建、修改和显示Microsoft Office格式的文件,特别是我们关注的Excel(.xlsx)文档。本教程将深入探讨如何利用POI在Java环境中实现...
POI导出POI导出POI导出POI导出POI导出POI导出POI导出POI导出POI导出POI导出POI导出POI导出POI导出POI导出POI导出POI导出POI导出POI导出POI导出POI导出POI导出POI导出POI导出POI导出POI导出POI导出POI导出POI导出POI...
Struts2和Apache POI是Java开发中处理Web应用程序数据导出到Excel的常用工具。...以上就是使用Struts2和Apache POI导出数据到Excel的基本流程和关键知识点,实际应用中可能需要根据具体需求进行调整和优化。
标题中的“POI实现的基于动态模板的EXCEL数据导出”是指利用Apache POI库来创建一个可以动态填充数据的Excel模板,从而实现大量数据的高效导出。Apache POI是一个开源项目,它允许Java开发者读写Microsoft Office...
POI框架导出Tree结构数据(连接线) 一、问题描述及现象需求说明 在效果评估系统中,存在指标管理和模板管理两个模块。模板管理中有一个导出模板功能,可以将模板导出到Excel表格中。模板下可以嵌套的是指标或模板...
本文将详细介绍如何利用Apache POI在Java Web环境中将数据导出到Excel。 首先,理解Apache POI的基本概念。POI提供了HSSF(Horrible Spreadsheet Format)用于处理老版本的Excel(.xls),而XSSF用于处理新版本的...
在Java中,使用POI导出数据到Excel文件通常涉及以下步骤: 1. **创建Workbook对象**:这是Excel文件的基础,可以是HSSFWorkbook(.xls)或XSSFWorkbook(.xlsx)。 2. **创建Sheet对象**:Sheet相当于Excel工作簿...
【作品名称】:基于Apache POI导出大数据量(百万级)Excel的实现 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【项目介绍】:...
以下是一个简化的示例,演示了如何使用POI导出Excel: ```java import org.apache.poi.ss.usermodel.*; import org.apache.poi.xssf.usermodel.XSSFWorkbook; import java.io.FileOutputStream; import java.io....
本实例源码着重讲解如何利用Apache POI来实现数据的Excel导出功能。 首先,我们需要了解Apache POI的基本概念。POI提供了HSSF(Horrible Spreadsheet Format)和XSSF(XML Spreadsheet Format)两个主要的API,分别...
总之,利用 Apache POI 实现多表头的 Excel 导出,需要理解 POI API,合理组织数据结构,以及灵活运用单元格合并和样式设置。结合提供的代码文件,你可以进一步研究和学习如何在实际项目中应用这些技术。
### POI将数据导出至Word的实例解析 #### 一、概述 Apache POI 是一个流行的 Java 库,用于处理 Microsoft Office 文件格式,包括 Word(.doc 和 .docx)、Excel(.xls 和 .xlsx)等。在本文中,我们将深入探讨...
在这个场景中,我们将专注于使用 POI 来在 PowerPoint(PPT)文件中创建多数据柱状图。Apache POI 的最新版本是 3.17,它提供了丰富的 API 来实现这个功能。以下是一些关键知识点: 1. **Apache POI API**:Apache ...
【标题】"POI导出(数据库数据)"所涉及的知识点主要集中在使用Apache POI库来导出数据库中的数据到Excel文件。Apache POI是一个流行的开源Java API,它允许开发者创建、修改和显示Microsoft Office格式的文件,尤其...
poi实现导入数据到excel模板,本来想上传poi的jar包,谁知限制我只能上传15M的文件,汗。。。。。 不知道啥时候开始要分了... 代码见: https://github.com/thisisnohi/nohi-doc poi实现导入数据到excel模板。...
标题中的“poi导出csv文件”指的是使用Apache POI库来生成CSV(逗号分隔值)文件。Apache POI是Java中一个流行的库,它主要用于处理Microsoft Office格式的文件,如Excel。在这个场景中,我们将探讨如何使用POI来...
java使用POI导出 Excel+图片工具类 ,里面含有poi jar包,只调用接口即可直接保存Excel。使用的时候需先把数据封装,具体包装需根据实际导出数据进行处理。文件demo中只提供包装格式。
springboot+poi导出指定格式Excel模板,完整项目,导出即用。springboot+poi导出指定格式Excel模板,完整项目,导出即用。springboot+poi导出指定格式Excel模板,完整项目,导出即用。springboot+poi导出指定格式...
在Java编程中,使用...总结起来,Java使用Apache POI导出大量数据需要考虑内存管理、性能优化、样式设置、错误处理等多个方面。通过合理的编程实践和策略,可以确保数据导出既快速又稳定,同时提供良好的用户体验。