首页 > 代码库 > web开发之导出excel工具类
web开发之导出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(); } }
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。