欢迎访问悦橙教程(wld5.com),关注java教程。悦橙教程  java问答|  每日更新
页面导航 : > > 文章正文

Java导出excel工具类,,web开发中,一个系统的

来源: javaer 分享于  点击 5357 次 点评:89

Java导出excel工具类,,web开发中,一个系统的


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();          }      }  
相关栏目:

用户点评