查询数据导出Excel,与导入excel

导出Excel

@PostMapping("/ExportAttendanceReport")
public void ExportAttendanceReport (HttpServletResponse response,@RequestBody Map<String, Object> paramMap){
	ResultDTO resultDTO;
	try{
		resultDTO = leaveApprovalPCSOA.doAttendanceReport(paramMap);
		@SuppressWarnings("unchecked")
		List<LeaveDTO> leavePOList = (List<LeaveDTO>) resultDTO.getResultValue();
		HSSFWorkbook workbook = new HSSFWorkbook();
		HSSFSheet sheet = workbook.createSheet("考勤表");
		List<String> sheetHeader = new ArrayList<String>();//设置表头
		sheetHeader.add("序号");
		sheetHeader.add("管理机构");
		sheetHeader.add("姓名");
		sheetHeader.add("工号");
		sheetHeader.add("请假类型");
		sheetHeader.add("请假开始时间");
		sheetHeader.add("请假结束时间");
		sheetHeader.add("持续天数");
		sheetHeader.add("请假原因");
		sheetHeader.add("审批状态");
		this.createHeader(workbook,sheet,sheetHeader);//创建表头
		int index = 0;
		// 设置日期格式
		// 新增数据行,并且设置单元格数据
		logger.info("考勤表查出数据长度" + leavePOList.size());
		logger.info("salaryquery查出的数据"+leavePOList.get(0).getName()+leavePOList.get(1).getName()+leavePOList.get(2).getName());
		for (int i = 0; i < leavePOList.size(); i++) {
			LeaveDTO leavePO = leavePOList.get(i);
			if ((i + 1) % 60000 == 0) { //如果数据超过6万条,建造下一个表
				sheet = workbook.createSheet("考勤表" + index);
				HSSFRow row = sheet.createRow(0);
				logger.info("查出数据长度" + i+"index"+index);
				HSSFCell cell;
				//设置加粗
				HSSFCellStyle style = workbook.createCellStyle();
				HSSFFont font = workbook.createFont();
				font.setBold(true);
				style.setAlignment(HSSFCellStyle.ALIGN_CENTER);
				style.setFont(font);
				for (int j = 0; j < sheetHeader.size(); j++) {
					cell = row.createCell(j);
					cell.setCellValue(sheetHeader.get(j));
					cell.setCellStyle(style);
				}
				index++;
				}
			HSSFRow row;
			if(i<=59998){
				 row = sheet.createRow((i + 1) - (index * 60000));
				 logger.info((i + 1) - (index * 60000));
			}else{
				 row = sheet.createRow((i + 2) - (index * 60000));
				 logger.info((i + 2) - (index * 60000));			}
			row.createCell(0).setCellValue(i+1);//序号
			row.createCell(1).setCellValue(leavePO.getManageCom());//管理机构
			row.createCell(2).setCellValue(leavePO.getName());//姓名
			row.createCell(3).setCellValue(leavePO.getAgentCode());//工号
			row.createCell(4).setCellValue(leavePO.getType());//请假类型
			row.createCell(5).setCellValue(leavePO.getStartDate());//请假开始时间
			row.createCell(6).setCellValue(leavePO.getEndDate());//请假结束时间
			row.createCell(7).setCellValue(leavePO.getDay());//请假持续时间
			row.createCell(8).setCellValue(leavePO.getReason());//请假理由		
			row.createCell(9).setCellValue(leavePO.getState());//审批状态
		}
	
	String currDate = DateUtil.date2String(new Date(), "yyyyMMddHHmmss");
	String excelName ="考勤明细报表" + currDate + ".xls";
	response.setContentType("application/vnd.ms-excel");
	this.setResponseHeader(response, excelName);
	OutputStream os = response.getOutputStream();
	workbook.write(os);
	os.flush();
	os.close();
	}catch(Exception e){
			logger.info("LeaveApprovalController.doAttendanceReport():考勤报表导出有误!原因为:" , e);
		}
}
public void createHeader(HSSFWorkbook workbook, HSSFSheet sheet, List<String> sheetHeader) {
	HSSFRow row = sheet.createRow(0);
	HSSFCellStyle style = workbook.createCellStyle();
	HSSFFont font = workbook.createFont();
	font.setBold(true);
	style.setAlignment(HSSFCellStyle.ALIGN_CENTER);
	style.setFont(font);
	HSSFCell cell;
	for (int i = 0; i < sheetHeader.size(); i++) {
		   cell = row.createCell(i);
		   cell.setCellValue(sheetHeader.get(i));
		   cell.setCellStyle(style);
	}
	
}
public void setResponseHeader(HttpServletResponse response, String fileName) {

	try {
		try {
			fileName = new String(fileName.getBytes(), "ISO8859-1");
		} catch (UnsupportedEncodingException e) {
			e.printStackTrace();
		}
		response.setContentType("application/octet-stream;charset=ISO8859-1");
		response.setHeader("Content-Disposition", "attachment;filename=" + fileName);
		response.addHeader("Pargam", "no-cache");
		response.addHeader("Cache-Control", "no-cache");
	} catch (Exception ex) {
		ex.printStackTrace();
	}
}
'''

导入Excel

package com.sinosig.sl.sssc.base.excel;
// 
import java.io.IOException;
import java.io.InputStream;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Date;
import java.util.List;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.DateUtil;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
 
/**
 * 被解析的Excel最好是什么样的呢?  
 * 单元格最好都是文本格式,保存数据前自己去转换,不用poi带的转换。
 * 第一列 和最后一列 必须是必填字段!!!这样的你用我这个Util,得到的List就很准确了,不会出现多余的行或列。
 * @author TMACJ
 * @version 0.000000.002899
 */
public class ImportExcelUtil {
	private final static String excel2003L =".xls";    //2003- 版本的excel
	private final static String excel2007U =".xlsx";   //2007+ 版本的excel
	
	static SimpleDateFormat sFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
    static short[] yyyyMMdd = {14, 31, 57, 58, 179, 184, 185, 186, 187, 188};
    static short[] HHmmss = {20, 32, 190, 191, 192};
    static List<short[]> yyyyMMddList = Arrays.asList(yyyyMMdd);
    static List<short[]> hhMMssList = Arrays.asList(HHmmss);
	/**
	 * 描述:获取IO流中的数据,组装成List<List<Object>>对象
	 * @param in,fileName
	 * @return
	 * @throws IOException 
	 */
	public static  List<List<String>> getBankListByExcel(InputStream in,String fileName) throws Exception{
		List<List<String>> list = null;
		
		//创建Excel工作薄
		Workbook work = ImportExcelUtil.getWorkbook(in,fileName);
		if(null == work){
			throw new Exception("创建Excel工作薄为空!");
		}
		Sheet sheet = null;
		Row row = null;
		Cell cell = null;
		
		list = new ArrayList<List<String>>();
		//遍历Excel中所有的sheet
		for (int i = 0; i < work.getNumberOfSheets(); i++) {
			sheet = work.getSheetAt(i);
			if(sheet==null){continue;}
			int totalCell = sheet.getRow(0).getPhysicalNumberOfCells();//标题行一共有多少列
			//遍历当前sheet中的所有行
			for (int j = sheet.getFirstRowNum(); j < sheet.getLastRowNum()+1; j++) {
				row = sheet.getRow(j);
				if(row==null || ImportExcelUtil.validateRow(row) || row.getPhysicalNumberOfCells() < totalCell){continue;} //3个条件,有一个为true就不会往list里加,不仅过滤空行还过滤了列数不够的行,这点要注意,要求表中前后的列都是必填的。
				//遍历所有的列
				List<String> li = new ArrayList<String>();
				for (int y = row.getFirstCellNum(); y < row.getLastCellNum(); y++) {
					cell = row.getCell(y);
					li.add(ImportExcelUtil.getCellData(cell));
				}
				list.add(li);
			}
			// 简单起见,这里只解析第一个工作簿!
			break;
		}
//		work.close();
		return list;
	}
	// 过滤空行,(其中一行的数据的确都为空,可是其原本的格式还在,并没有连带删除,这样计算出来的行数就不真实,比真实的大)
	private static boolean validateRow(Row row) throws Exception{
//		for (Cell cell : row) {
//			
//		}
		//只判断第一列。第一列为空就代表这行的数据无效
		if (row.getCell(0).getCellType() == Cell.CELL_TYPE_BLANK || "".equals(ImportExcelUtil.getCellData(row.getCell(0)))) {
			return true;
		}
		return false;//不是空行
	}
	/**
	 * 描述:根据文件后缀,自适应上传文件的版本 
	 * @param inStr,fileName
	 * @return
	 * @throws Exception
	 */
	public static  Workbook getWorkbook(InputStream inStr,String fileType) throws Exception{
		Workbook wb = null;
		String extension = fileType.lastIndexOf(".") == -1 ? "" : fileType.substring(fileType.lastIndexOf(".") + 1);
//		contains() 
		 fileType="."+extension;
		if(excel2003L.equals(fileType)){
			wb = new HSSFWorkbook(inStr);  //2003-
		}
		else if(excel2007U.equals(fileType)){
			wb = new XSSFWorkbook(inStr);  //2007+
		}
		else{
			throw new Exception("解析的文件格式有误!");
		}
		return wb;
	}
	
	/**
     * 获取单元中值(字符串类型)
     *
     * @param cell
     * @return
	 * @throws Exception 
     */
    public static String getCellData(Cell cell) throws Exception {
        String cellValue = "";
        if (cell != null) {
            try {
                switch (cell.getCellType()) {
                    case Cell.CELL_TYPE_BLANK://空白
                        cellValue = "";
                        break;
                    case Cell.CELL_TYPE_NUMERIC: //数值型 0----日期类型也是数值型的一种
                        if (DateUtil.isCellDateFormatted(cell)) {
                            short format = cell.getCellStyle().getDataFormat();
 
                            if (yyyyMMddList.contains(format)) {
                                sFormat = new SimpleDateFormat("yyyy-MM-dd");
                            } else if (hhMMssList.contains(format)) {
                                sFormat = new SimpleDateFormat("HH:mm:ss");
                            }
                            Date date = cell.getDateCellValue();
                            cellValue = sFormat.format(date);
                        } else {
                        	cell.setCellType(Cell.CELL_TYPE_STRING);
                        	cellValue = replaceBlank(cell.getStringCellValue());
                            //Double numberDate = new BigDecimal(cell.getNumericCellValue()).setScale(2, BigDecimal.ROUND_HALF_UP).doubleValue();//似乎还是有点问题
                            //cellValue = numberDate + "";
                        }
                        break;
                    case Cell.CELL_TYPE_STRING: //字符串型 1
                        cellValue = replaceBlank(cell.getStringCellValue());
                        break;
                    case Cell.CELL_TYPE_FORMULA: //公式型 2
                        cell.setCellType(Cell.CELL_TYPE_STRING);
                        cellValue = replaceBlank(cell.getStringCellValue());
                        break;
                    case Cell.CELL_TYPE_BOOLEAN: //布尔型 4
                        cellValue = String.valueOf(cell.getBooleanCellValue());
                        break;
                    case Cell.CELL_TYPE_ERROR: //错误 5
                        cellValue = "!#REF!";
                        break;
                }
            } catch (Exception e) {
            	throw new Exception("读取Excel单元格数据出错:" + e.getMessage());
            }
        }
        return cellValue;
    }
    
    public static String replaceBlank(String source) {
        String dest = "";
        if (source != null) {
            Pattern p = Pattern.compile("\t|\r|\n");
            Matcher m = p.matcher(source);
            dest = m.replaceAll("");
        }
        return dest.trim();
    }
    
}

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值