使用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);
        }
	}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值