<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    隨筆-153  評論-235  文章-19  trackbacks-0
          項目中要寫excel,把這個例子寫出來,以后可以看。

    1.寫excel類
    package net.blogjava.chenlb;

    import java.io.IOException;
    import java.io.OutputStream;
    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);
            }
        }
    }

    2.使用
        public void testWriteExcel() {
            List datas 
    = new ArrayList();
            String[] data 
    = {"1""chenlb"};
            datas.add(data);
            
    try {
                OutputStream out 
    = new FileOutputStream(new File("doc/chenlb.blogjava.net.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();
            }
            
        }

    posted on 2007-10-29 10:52 流浪汗 閱讀(5912) 評論(1)  編輯  收藏 所屬分類: JAVA/J2EE

    評論:
    # re: jxl 寫 excel 2012-03-31 14:46 | 大狗
    寫的非常好啊,很有用,內容簡練,不像網上別的例子寫了一大堆冗余的東西。  回復  更多評論
      
    主站蜘蛛池模板: 成人免费视频国产| 成人A片产无码免费视频在线观看 成人电影在线免费观看 | 久久亚洲精品国产精品| 国产成人免费网站| 亚洲av永久无码天堂网| 亚洲国产精品综合久久一线 | 一个人免费视频在线观看www | 亚洲爆乳少妇无码激情| 亚洲午夜久久久久久久久久| 亚洲一区免费视频| 久久久久久亚洲精品不卡| **真实毛片免费观看| 猫咪免费人成在线网站| 亚洲av日韩av激情亚洲| 国产又大又长又粗又硬的免费视频| 中文字幕在线视频免费| 亚洲无码精品浪潮| 黄页网站在线看免费| 男女一进一出抽搐免费视频 | 亚洲五月综合缴情婷婷| 国产综合精品久久亚洲| 成年女人看片免费视频播放器| 香蕉视频在线免费看| 看亚洲a级一级毛片| 亚洲国产精品久久人人爱| 亚洲日韩中文字幕在线播放| 在线精品免费视频无码的| 久久久久久久99精品免费 | 在线aⅴ亚洲中文字幕| 亚洲AV无码专区亚洲AV伊甸园| 国产女高清在线看免费观看 | 国产偷v国产偷v亚洲高清| 国产高清免费的视频| 国产电影午夜成年免费视频 | 99久热只有精品视频免费观看17| 免费一级毛片在线播放放视频| 456亚洲人成影院在线观| 久久久久久亚洲精品成人| 中文亚洲AV片不卡在线观看| 国产一区二区三区在线观看免费| 午夜国产精品免费观看|