java web通过POI把数据库数据写入Excel表格(自动生成标题栏)

一,把相关参数从前台传递给后台

@SuppressWarnings("unchecked")
    @RequestMapping(value = "/outExcel", method = RequestMethod.POST)
    public void outExcel(
          //前台相关参数除了columns是集合其他都是字符串
            @RequestParam(value = "columns", required = false, defaultValue = "") String columns,//表格标题栏
            @RequestParam(value = "brand", required = false, defaultValue = "") String brand,//数据库查询参数
            @RequestParam(value = "prodcode", required = false, defaultValue = "") String prodcode,//数据库查询参数
            @RequestParam(value = "cargoname", required = false, defaultValue = "") String cargoname,//数据库查询参数
            @RequestParam(value = "yesorno", required = false, defaultValue = "") String yesorno,//数据库查询参数
            @RequestParam(value = "desiner", required = false, defaultValue = "") String desiner,//数据库查询参数
            @RequestParam(value = "tabnum", required = false, defaultValue = "") String tabnum,//数据库查询参数
            @RequestParam(value = "fname", required = false, defaultValue = "") String fname,//表格名称
            @RequestParam(value = "exporttype", required = false, defaultValue = "Grid") String exporttype,//生成表格类型
            HttpServletRequest request, HttpServletResponse response) {

        try {
            String results = "";
            OutputStream out = response.getOutputStream();
            response.reset();// 清空输出流

            response.setCharacterEncoding("UTF-8");// 设置相应内容的编码格式
            fname = java.net.URLEncoder.encode(fname, "UTF-8");
            response.setHeader("Content-Disposition", "attachment;filename="
                    + new String(fname.getBytes("UTF-8"), "GBK") + ".xlsx");
            response.setContentType("application/ms-excel");// 定义输出类型
            net.sf.json.JSONArray listColums = null;
            net.sf.json.JSONArray mapResults = null;
            results = getExcelResults(brand, prodcode, cargoname, yesorno,
                    desiner, tabnum);
            if (!"".equals(columns) && !"".equals(results)) {
                listColums = net.sf.json.JSONArray.fromObject(columns);

                mapResults = net.sf.json.JSONArray.fromObject(results
                        .toString());

                ExcelUtils.writeExcelTest(out, fname, listColums, mapResults);
            }
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }

//查询数据库数据

    private String getExcelResults(String brand, String prodcode,
            String cargoname, String yesorno, String desiner, String tabnum) {
        String year = DateUtils.getCurrentYear();
        String results = "";
        String sqlc = "SELECT  prod_code,sku,brand,type_code,tag_price,national_code,dtbt_pep,deal_status,explain,plan_time,prod_type,prod_size,prod_color,prod_season,prod_priority,create_time,prod_sex,prod_time,prod_list_time,class_name,arive_property,same_prod,make_time,desin_nature,prod_name,on_marked,main_id from desin_plan where prod_type<>-1 ";
        if (!"".equals(tabnum)) {
            sqlc += " AND  prod_type='" + tabnum + "'";
        }
        /*
         * if (!"".equals(brand)) { sqlc += " AND  brand='" + brand + "'"; }
         */
        if (!"".equals(prodcode)) {

            sqlc += " AND  prod_code IN ('" + prodcode + "')";
        }
        if (!"".equals(cargoname)) {

            sqlc += " AND  prod_name LIKE '%" + cargoname + "%'";
        }
        if (!"".equals(yesorno)) {

            sqlc += " AND  desin_nature = '" + yesorno + "'";
        }
        if (!"".equals(desiner)) {
            sqlc += " AND  dtbt_pep = '" + desiner + "'";
        }
        if (!"".equals(year)) {
            sqlc += " AND  create_time BETWEEN '" + year + "' AND '"
                    + (Integer.parseInt(year) + 1) + "'";
        }
        // System.out.println("\n sqlc===" + sqlc);
        results = jdbcWrap.queryJson(sqlc);
        try {

            Thread.sleep(2000);
        } catch (InterruptedException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        return results;
    }

二、写入Excel表格

/**
     * 创建Excel文件
     * 
     * @param out
     *            filepath 文件全路径
     * @param sheetName
     *            新Sheet页的名字
     * @param titles
     *            表头
     * @param values
     *            每行的单元格
     */
    public static boolean writeExcelTest(OutputStream out, String sheetName,
            List<Map<String, String>> titles, List<Map<String, Object>> values)
            throws IOException {
        boolean success = false;
        Workbook workbook;
        workbook = new XSSFWorkbook();

        // 生成一个表格
        Sheet sheet;
        if (StringUtils.isBlank(sheetName)) {
            // name 为空则使用默认值
            sheet = workbook.createSheet();
        } else {
            sheet = workbook.createSheet(sheetName);
        }
        // 设置表格默认列宽度为15个字节
        sheet.setDefaultColumnWidth((short) 15);
        // 生成样式
        Map<String, CellStyle> styles = createStyles(workbook);
        // 创建标题行
        Row row = sheet.createRow(0);
        // 存储标题在Excel文件中的序号
        Map<String, Integer> titleOrder = Maps.newHashMap();
        for (int i = 0; i < titles.size(); i++) {
            Cell cell = row.createCell(i);
            cell.setCellStyle(styles.get("header"));
            String title = titles.get(i).get("header");
            String name = titles.get(i).get("field");
            cell.setCellValue(title);
            titleOrder.put(name, i);
        }
        // System.out.print("\n titleOrder=" + titleOrder);
        // 写入正文
        Iterator<Map<String, Object>> iterator = values.iterator();

        // 行号
        int index = 1;
        while (iterator.hasNext()) {
            row = sheet.createRow(index);
            Map<String, Object> value = iterator.next();
            // System.out.print("\n value==" + value);
            for (Map.Entry<String, Object> map : value.entrySet()) {
                // 获取列名
                String title = map.getKey();
                // System.out.print("\n  map=" + map);
                // 根据列名获取序号
                int i = titleOrder.get(title);
                // System.out.print("\n i==" + i);
                // 在指定序号处创建cell
                Cell cell = row.createCell(i);
                // 设置cell的样式
                if (index % 2 == 1) {
                    cell.setCellStyle(styles.get("cellA"));
                } else {
                    cell.setCellStyle(styles.get("cellB"));
                }
                // 获取列的值
                Object object = map.getValue();
                // 判断object的类型
                SimpleDateFormat simpleDateFormat = new SimpleDateFormat(
                        "yyyy-MM-dd HH:mm:ss");
                if (object instanceof Double) {
                    cell.setCellValue((Double) object);
                } else if (object instanceof Date) {
                    String time = simpleDateFormat.format((Date) object);
                    cell.setCellValue(time);
                } else if (object instanceof Calendar) {
                    Calendar calendar = (Calendar) object;
                    String time = simpleDateFormat.format(calendar.getTime());
                    cell.setCellValue(time);
                } else if (object instanceof Boolean) {
                    cell.setCellValue((Boolean) object);
                } else {
                    if (object != null) {
                        cell.setCellValue(object.toString());
                    }
                }
            }
            index++;
        }
        try {
            workbook.write(out);
            success = true;
        } finally {
            if (out != null) {
                out.close();
            }
            if (workbook != null) {
                workbook.close();
            }
        }
        return success;
    }

搞定收工!!!!!!!!!!!!!!!!!!!!!

部分代码的解读,domo里面包含jar package excelManager; import java.io.File; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; import java.io.OutputStream; import java.util.ArrayList; import java.util.List; import jxl.Workbook; import jxl.write.Label; import jxl.write.WritableSheet; import jxl.write.WritableWorkbook; import jxl.write.WriteException; import jxl.write.biff.RowsExceededException; /** * Jxl 的 Excel数据器. * @author chenlb 2007-10-29 上午10:39:31 */ public class JxlExcelWriter { /** * @param datas 封装着Object[]的列表, 一般是String内容. * @param title 每个sheet里的标题. */ public void writeExcel(OutputStream out, List datas, String[] title) { if(datas == null) { throw new IllegalArgumentException("写excel流需要List参数!"); } try { WritableWorkbook workbook = Workbook.createWorkbook(out); WritableSheet ws = workbook.createSheet("sheet 1", 0); int rowNum = 0; //要写的行 if(title != null) { putRow(ws, 0, title);//压入标题 rowNum = 1; } for(int i=0; i<datas.size(); i++, rowNum++) {//写sheet Object[] cells = (Object[]) datas.get(i); putRow(ws, rowNum, cells); //压一行到sheet } workbook.write(); workbook.close(); //一定要关闭, 否则没有保存Excel } catch (RowsExceededException e) { System.out.println("jxl write RowsExceededException: "+e.getMessage()); } catch (WriteException e) { System.out.println("jxl write WriteException: "+e.getMessage()); } catch (IOException e) { System.out.println("jxl write file i/o exception!, cause by: "+e.getMessage()); } } private void putRow(WritableSheet ws, int rowNum, Object[] cells) throws RowsExceededException, WriteException { for(int j=0; j<cells.length; j++) {//写一行 Label cell = new Label(j, rowNum, ""+cells[j]); ws.addCell(cell); } } public static void main(String[] args) { List datas = new ArrayList(); String[] data = {"1", "chenlb"}; datas.add(data); try { OutputStream out = new FileOutputStream(new File("e://a.xls")); JxlExcelWriter jxlExcelWriter = new JxlExcelWriter(); jxlExcelWriter.writeExcel(out, datas, new String[] {"Id", "name"}); out.close(); } catch (FileNotFoundException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } } }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值