zoukankan      html  css  js  c++  java
  • javaEE开发之导出excel工具类

    web开发中,一个系统的普通需求也包含导出excel,一般採用POI做统计报表导出excel。

    导出excel工具类:

    import java.io.FileOutputStream;
    import java.io.IOException;
    import java.io.OutputStream;
    import java.util.List;
    import java.util.Map;
    
    import org.apache.poi.hssf.usermodel.HSSFCell;
    import org.apache.poi.hssf.usermodel.HSSFRichTextString;
    import org.apache.poi.hssf.usermodel.HSSFRow;
    import org.apache.poi.hssf.usermodel.HSSFSheet;
    import org.apache.poi.hssf.usermodel.HSSFWorkbook;
    
    public class ExportExcel {
    
    	private ExportExcel() {
    		super();
    	}
    
    	public static void exportExcel(List<Object> list, Map<Integer, Long> map,
    			String[] titles) throws IOException {
    		// 创建Excel文档
    		HSSFWorkbook hwb = new HSSFWorkbook();
    		// sheet 相应一个工作页
    		HSSFSheet sheet = hwb.createSheet("exportReport");
    		int colNum = titles.length;
    		// 创建第一行
    		HSSFRow firstrow = sheet.createRow(0);
    		HSSFCell[] firstcell = new HSSFCell[colNum];
    		for (int col = 0; col < colNum; col++) {
    			firstcell[col] = firstrow.createCell(col);
    			firstcell[col].setCellValue(new HSSFRichTextString(titles[col]));
    		}
    
    		// 插入记录
    		int rowNum = map.size();
    		for (int i = 0; i < rowNum; i++) {
    			// 从第二行開始
    			HSSFRow row = sheet.createRow(i + 1);
    			// 插入list中的字段
    			for (int col = 0; col < colNum - 2; col++) {
    				HSSFCell cell = row.createCell(col);
    				cell.setCellValue(list.get(col).toString());
    			}
    			// 插入月份或日期
    			row.createCell(colNum - 2).setCellValue(i + 1);
    			// 插入总量
    			row.createCell(colNum - 1).setCellValue(map.get(i + 1));
    		}
    		String fileName = titles[1].substring(0, 2);
    		if (colNum == 4) {
    			fileName += list.get(0) + "_" + list.get(1) + "年_年度报表";
    		} else if (colNum == 5) {
    			fileName += list.get(0) + "_" + list.get(1) + "年" + list.get(2)
    					+ "月_月度报表";
    		}
    		// 创建文件输出流。准备输出电子表格
    		OutputStream out = new FileOutputStream("../webapps/UsedMallMinaServer/files/"
    				+ fileName + ".xls");
    		hwb.write(out);
    		out.close();
    	}
    }


  • 相关阅读:
    BZOJ_1095_[ZJOI2007]Hide 捉迷藏_动态点分治+堆
    BZOJ_2216_[Poi2011]Lightning Conductor_决策单调性
    BZOJ_2208_[Jsoi2010]连通数_强连通分量+拓扑排序+手写bitset
    BZOJ_2438_[中山市选2011]杀人游戏 _强连通分量
    BZOJ_3545_[ONTAK2010]Peaks_主席树+倍增+kruscal重构树+dfs序
    BZOJ_1671_[Usaco2005 Dec]Knights of Ni 骑士_BFS
    BZOJ_3566_[SHOI2014]概率充电器_概率+树形DP
    自动驾驶课程学习
    java:String使用equals和==比较的区别
    为什么java的main方法必须是静态的
  • 原文地址:https://www.cnblogs.com/zhchoutai/p/6964565.html
Copyright © 2011-2022 走看看