使用jxl操作excel表格


package com.app.excel;

import java.io.File;
import java.io.IOException;

import jxl.Cell;
import jxl.Sheet;
import jxl.Workbook;
import jxl.read.biff.BiffException;
import jxl.write.Label;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;

/**
 * excel文件操作類
 * @author Administrator
 *
 */
public class Demo {
	public static void main(String[] args) {
		String excel = "C:\\Users\\Administrator\\Desktop\\test\\22.xls";
		String excel1 = "C:\\Users\\Administrator\\Desktop\\test\\222.xls";
		readExcel(excel);
		//createExcel(excel1);
	}
	
	/**
	 * 讀取一個excel
	 * @param excel
	 */
	public static void readExcel(String excel){
		Workbook wb = null;
		if(excel != null && !"".equals(excel)){
			try {
				//構造Workbook(工作簿對象)
				try {
					wb = Workbook.getWorkbook(new File(excel));
				} catch (IOException e) {
					e.printStackTrace();
				}
			} catch (BiffException e) {
				e.printStackTrace();
			}
			if(wb != null){
				//如果workbook不爲空
				//獲得工作表對象
				Sheet[] sheets = wb.getSheets();
				for(int i=0;i<sheets.length;i++){
					int rowNum = sheets[i].getRows();//行數
					int colNum = sheets[i].getColumns();//列數
					for(int j=0;j<rowNum;j++){
						for(int k=0;k<colNum;k++){
							Cell cell = sheets[i].getCell(k,j);//單元格
							String value = cell.getContents();//獲得單元格的值
							System.out.println(j+"行-"+k+"列-值爲:"+value);
						}
					}
				}
			}
			wb.close();
		}
	}
	
	/**
	 * 生成一個excel文件
	 * @param excel
	 */
	public static void createExcel(String excel){
		try {
            // 打開文件
            WritableWorkbook book = Workbook.createWorkbook(new File(excel));
            // 生成名爲“第一頁”的工作表,參數0表示這是第一頁
            WritableSheet sheet = book.createSheet("第一頁", 0);
            // 在Label對象的構造子中指名單元格位置是第一列第一行(0,0)
            // 以及單元格內容爲test
            Label label = new Label(0, 0, "test");

            // 將定義好的單元格添加到工作表中
            sheet.addCell(label);

            /*
             * 生成一個保存數字的單元格 必須使用Number的完整包路徑,否則有語法歧義 單元格位置是第二列,第一行,值爲789.123
             */
            jxl.write.Number number = new jxl.write.Number(1, 0, 555.12541);
            sheet.addCell(number);

            // 寫入數據並關閉文件
            book.write();
            book.close();

        } catch (Exception e) {
            System.out.println(e);
        }
	}
}

發佈了25 篇原創文章 · 獲贊 3 · 訪問量 7萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章