使用模板导出Excel

首先需要导入相关jar包
代码示例:
.jsp文件

<body>
 <table id="test" style="width:400px;font-size: 12px;text-align:center;"  border="1"  cellspacing="0" bordercolor="black">
    <tr>
       <th>一一</th><th>一二</th><th>一三</th><th>一四</th><th></th><th></th>
    </tr>
     <tr>
       <td>二一</td><td>二二</td><td>二三</td><td>二四</td><td></td><td></td>
    </tr>
     <tr>
       <td>三一</td><td>三二</td><td>三三</td><td>三四</td><td></td><td></td>
    </tr>
     <tr>
       <td>四一</td><td>四儿</td><td>四三</td><td>四四</td><td></td><td></td>
    </tr>
     <tr>
       <td>五一</td><td>五二</td><td>五三</td><td>五四</td><td></td><td></td>
    </tr>
</table> 
</body>

2.js文件

<script type="text/javascript">
 function btnExcel(){
     var table=document.getElementById("test");
     var tableData="";
        var rows=table.rows.length;
        for(var i=0;i<rows;i++){
            for(var j=0;j<table.rows[i].cells.length;j++){
                tableData+=table.rows[i].cells[j].innerHTML+';';
            }

        }
        alert(tableData);
     $.ajax({ 
                    type:'POST',  
                    url:'firstservlet?time=new Date()', 
                    data:{"condition":tableData,
                           "rows":rows
                    },
                    dataType:'text',  
                    success:function(){
                       alert("导出成功");
                    },  
                    error: function(){
                        alert("导出失败"); 
                    }  
        });  
}
</script>

3.后台相关代码

protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        req.setCharacterEncoding("UTF-8");
 String[] tabString;
         String testData=req.getParameter("condition");
         int rows=Integer.parseInt(req.getParameter("rows"));
          tabString=testData.split(";");
         for(int i=0;i<tabString.length;i++){
             System.out.println("当前的值是"+tabString[i]);
         }
 XSSFWorkbook xwb =null;
        // System.out.println("\\DaoChuExcel\\WebContent\\template\\testExcel.xlsx");
         FileInputStream fis = new FileInputStream("F:/testDemo.xlsx");  

            // xwb= new XSSFWorkbook();
             xwb = new XSSFWorkbook(fis);
    XSSFFont font=xwb.createFont();
        font.setFontName("宋体");
        font.setFontHeight(10); 
        font.setColor(new HSSFColor.BLUE().getIndex());
        FileOutputStream fileout = null; 
        XSSFCellStyle CellStyle = xwb.createCellStyle();
        CellStyle.setFillForegroundColor((short) 13);// 设置背景色
        CellStyle.setFillPattern(XSSFCellStyle.SOLID_FOREGROUND);
        CellStyle.setFont(font);
XSSFSheet sheet =xwb.getSheetAt(0);
        //XSSFSheet sheet=xwb.createSheet("Sheetxx");
        int column=tabString.length/rows;
        int m=0;        
        for(int i=2;i<rows+2;i++){
             XSSFRow rowi=sheet.createRow(i);
             for(int j=0;j<column;j++){
                XSSFCell cell=rowi.createCell(j);
                cell.setCellValue(tabString[m]);
                //cell.setCellStyle(CellStyle);
                    m++;
                }
        }
        try {  

            fileout = new FileOutputStream("F:\\textdemo1.xlsx");  
            xwb.write(fileout);        
        } catch (IOException e) {  
            System.out.println(e.toString());  
        } finally {  
            try {  
                fileout.close();  
            } catch (IOException e) {  
                System.out.println(e.toString());  
            }  
        }     
}

最后效果图
这里写图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值