首页 > 代码库 > java数据导出成EXCEL

java数据导出成EXCEL

/**     *      * @param out 输出流     * @param maplist 数据     * @param title 标题     * @param headers 表头     * @param keys 表头对应的字段名     * @return     */    public static boolean getExcelDao(OutputStream out,            List<Map<String, Object>> maplist, String title, String[] headers,String keys[]) {        try {            // 创建一个工作薄            HSSFWorkbook workbook = new HSSFWorkbook();            // 创建一个带有名称的工作页            HSSFSheet sheet = workbook.createSheet(title);                        sheet.setDefaultColumnWidth(25);                        // 生成一个样式            HSSFCellStyle style = workbook.createCellStyle();            // 设置这些样式            style.setFillForegroundColor(HSSFColor.SKY_BLUE.index);            style.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);            style.setBorderBottom(HSSFCellStyle.BORDER_THIN);            style.setBorderLeft(HSSFCellStyle.BORDER_THIN);            style.setBorderRight(HSSFCellStyle.BORDER_THIN);            style.setBorderTop(HSSFCellStyle.BORDER_THIN);            style.setAlignment(HSSFCellStyle.ALIGN_CENTER);            // 生成一个字体            HSSFFont font = workbook.createFont();            font.setColor(HSSFColor.VIOLET.index);            font.setFontHeightInPoints((short) 12);            font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);            // 把字体应用到当前的样式            style.setFont(font);                                    // 生成并设置另一个样式            HSSFCellStyle style2 = workbook.createCellStyle();            style2.setFillForegroundColor(HSSFColor.LIGHT_YELLOW.index);            style2.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);            style2.setBorderBottom(HSSFCellStyle.BORDER_THIN);            style2.setBorderLeft(HSSFCellStyle.BORDER_THIN);            style2.setBorderRight(HSSFCellStyle.BORDER_THIN);            style2.setBorderTop(HSSFCellStyle.BORDER_THIN);            style2.setAlignment(HSSFCellStyle.ALIGN_CENTER);            style2.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);            // 生成另一个字体            HSSFFont font2 = workbook.createFont();            font2.setBoldweight(HSSFFont.BOLDWEIGHT_NORMAL);            // 把字体应用到当前的样式            style2.setFont(font2);                                                            // 产生坐标行            // 标题行            HSSFRow row = sheet.createRow(0);            HSSFCell cell = row.createCell(0);            cell.setCellStyle(style);                        cell.setCellValue(title);            // 使标题居中,合并单元格 四个参数 起始行列 结束行列            if (headers != null && headers.length > 0)                sheet.addMergedRegion(new CellRangeAddress(0, 0, 0,                        headers.length - 1));            else                sheet.addMergedRegion(new CellRangeAddress(0, 0, 0, 1));            // 产生表头            row = sheet.createRow(1);            for (int i = 0; i < headers.length; i++) {                cell = row.createCell(i);                cell.setCellStyle(style);                cell.setCellValue(headers[i]);            }            // 产生内容            for (int i = 0; i < maplist.size(); i++) {                Map<String, Object> objectmap = maplist.get(i);                row = sheet.createRow(i + 2);                int count = 0;//遍历MAP                for(String key:keys){                    cell = row.createCell(count);                    cell.setCellStyle(style2);                    cell.setCellValue(String.valueOf(objectmap.get(key)).equals("null")?"":objectmap.get(key)+"");                    count++;                }                /*for (Entry<String, Object> entry : objectmap.entrySet()) {                    // System.out.println("key= " + entry.getKey() +                    // " and value= "http://www.mamicode.com/+ entry.getValue());>*/            }            try {                workbook.write(out);                return true;            } catch (IOException e) {                e.printStackTrace();                return false;            }finally {                workbook.close();            }        } catch (Exception e) {            e.printStackTrace();            return false;        }    }


使用
String keys[]={"id","mname","o3title","num","userid","useraddress","Getphone","postname","postage","flagname","buildtime","kjtime"};            String headers[]={"订单号","品类","商品名称","夺宝次数","用户ID","地址","号码","快递","快递单号","订单状态","下单时间","开奖时间"};                    //orderServiceImpl.query_queryListAll(query, columns, tablename, sort)            //System.out.println(maplist.toString());            OutputStream outputStream = response.getOutputStream();            ExcelUtil.getExcelDao(outputStream, maplist2, title, headers, keys);            outputStream.close();

 




 

java数据导出成EXCEL