java jxl操作excel进行导入导出

主要的任务还是贴代码,这段代码实现了基本的java操作excel进行导入导出的操作。

ReadWriteExcelUtil.java

Java代码 复制代码 收藏代码
  1. package com.dsh.javaexcel.util; 
  2.  
  3. import java.io.File; 
  4. import java.io.IOException; 
  5.  
  6. import jxl.Cell; 
  7. import jxl.Sheet; 
  8. import jxl.Workbook; 
  9. import jxl.read.biff.BiffException; 
  10. import jxl.write.Label; 
  11. import jxl.write.WritableSheet; 
  12. import jxl.write.WritableWorkbook; 
  13. import jxl.write.WriteException; 
  14. import jxl.write.biff.RowsExceededException; 
  15.  
  16. public class ReadWriteExcelUtil { 
  17.  
  18.     /**
  19.      * @param args
  20.      */ 
  21.     public staticvoid main(String[] args) { 
  22.         String fileName = "d:" + File.separator +"test.xls"
  23.         System.out.println(ReadWriteExcelUtil.readExcel(fileName)); 
  24.         String fileName1 = "d:" + File.separator +"abc.xls"
  25.         ReadWriteExcelUtil.writeExcel(fileName1); 
  26.     } 
  27.  
  28.     /**
  29.      * 從excel文件中讀取所有的內容
  30.      *
  31.      * @param file
  32.      *            excel文件
  33.      * @return excel文件的內容
  34.      */ 
  35.     public static String readExcel(String fileName) { 
  36.         StringBuffer sb = new StringBuffer(); 
  37.         Workbook wb = null
  38.         try
  39.             // 构造Workbook(工作薄)对象 
  40.             wb = Workbook.getWorkbook(new File(fileName)); 
  41.         } catch (BiffException e) { 
  42.             e.printStackTrace(); 
  43.         } catch (IOException e) { 
  44.             e.printStackTrace(); 
  45.         } 
  46.  
  47.         if (wb == null
  48.             return null
  49.  
  50.         // 获得了Workbook对象之后,就可以通过它得到Sheet(工作表)对象了 
  51.         Sheet[] sheet = wb.getSheets(); 
  52.  
  53.         if (sheet != null && sheet.length >0) { 
  54.             // 对每个工作表进行循环 
  55.             for (int i =0; i < sheet.length; i++) { 
  56.                 // 得到当前工作表的行数 
  57.                 int rowNum = sheet[i].getRows(); 
  58.                 for (int j =0; j < rowNum; j++) { 
  59.                     // 得到当前行的所有单元格 
  60.                     Cell[] cells = sheet[i].getRow(j); 
  61.                     if (cells != null && cells.length > 0) { 
  62.                         // 对每个单元格进行循环 
  63.                         for (int k =0; k < cells.length; k++) { 
  64.                             // 读取当前单元格的值 
  65.                             String cellValue = cells[k].getContents(); 
  66.                             sb.append(cellValue + "\t"); 
  67.                         } 
  68.                     } 
  69.                     sb.append("\r\n"); 
  70.                 } 
  71.                 sb.append("\r\n"); 
  72.             } 
  73.         } 
  74.         // 最后关闭资源,释放内存 
  75.         wb.close(); 
  76.         return sb.toString(); 
  77.     } 
  78.  
  79.     /**
  80.      * 把內容寫入excel文件中
  81.      *
  82.      * @param fileName
  83.      *            要寫入的文件的名稱
  84.      */ 
  85.     public staticvoid writeExcel(String fileName) { 
  86.         WritableWorkbook wwb = null
  87.         try
  88.             // 首先要使用Workbook类的工厂方法创建一个可写入的工作薄(Workbook)对象 
  89.             wwb = Workbook.createWorkbook(new File(fileName)); 
  90.         } catch (IOException e) { 
  91.             e.printStackTrace(); 
  92.         } 
  93.         if (wwb != null) { 
  94.             // 创建一个可写入的工作表 
  95.             // Workbook的createSheet方法有两个参数,第一个是工作表的名称,第二个是工作表在工作薄中的位置 
  96.             WritableSheet ws = wwb.createSheet("sheet1",0); 
  97.  
  98.             // 下面开始添加单元格 
  99.             for (int i =0; i < 10; i++) { 
  100.                 for (int j =0; j < 5; j++) { 
  101.                     // 这里需要注意的是,在Excel中,第一个参数表示列,第二个表示行 
  102.                     Label labelC = new Label(j, i,"这是第" + (i + 1) +"行,第" 
  103.                             + (j + 1) +"列"); 
  104.                     try
  105.                         // 将生成的单元格添加到工作表中 
  106.                         ws.addCell(labelC); 
  107.                     } catch (RowsExceededException e) { 
  108.                         e.printStackTrace(); 
  109.                     } catch (WriteException e) { 
  110.                         e.printStackTrace(); 
  111.                     } 
  112.  
  113.                 } 
  114.             } 
  115.  
  116.             try
  117.                 // 从内存中写入文件中 
  118.                 wwb.write(); 
  119.                 // 关闭资源,释放内存 
  120.                 wwb.close(); 
  121.             } catch (IOException e) { 
  122.                 e.printStackTrace(); 
  123.             } catch (WriteException e) { 
  124.                 e.printStackTrace(); 
  125.             } 
  126.         } 
  127.     } 
  128.  
package com.dsh.javaexcel.util;

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;
import jxl.write.WriteException;
import jxl.write.biff.RowsExceededException;

public class ReadWriteExcelUtil {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		String fileName = "d:" + File.separator + "test.xls";
		System.out.println(ReadWriteExcelUtil.readExcel(fileName));
		String fileName1 = "d:" + File.separator + "abc.xls";
		ReadWriteExcelUtil.writeExcel(fileName1);
	}

	/**
	 * 從excel文件中讀取所有的內容
	 * 
	 * @param file
	 *            excel文件
	 * @return excel文件的內容
	 */
	public static String readExcel(String fileName) {
		StringBuffer sb = new StringBuffer();
		Workbook wb = null;
		try {
			// 构造Workbook(工作薄)对象
			wb = Workbook.getWorkbook(new File(fileName));
		} catch (BiffException e) {
			e.printStackTrace();
		} catch (IOException e) {
			e.printStackTrace();
		}

		if (wb == null)
			return null;

		// 获得了Workbook对象之后,就可以通过它得到Sheet(工作表)对象了
		Sheet[] sheet = wb.getSheets();

		if (sheet != null && sheet.length > 0) {
			// 对每个工作表进行循环
			for (int i = 0; i < sheet.length; i++) {
				// 得到当前工作表的行数
				int rowNum = sheet[i].getRows();
				for (int j = 0; j < rowNum; j++) {
					// 得到当前行的所有单元格
					Cell[] cells = sheet[i].getRow(j);
					if (cells != null && cells.length > 0) {
						// 对每个单元格进行循环
						for (int k = 0; k < cells.length; k++) {
							// 读取当前单元格的值
							String cellValue = cells[k].getContents();
							sb.append(cellValue + "\t");
						}
					}
					sb.append("\r\n");
				}
				sb.append("\r\n");
			}
		}
		// 最后关闭资源,释放内存
		wb.close();
		return sb.toString();
	}

	/**
	 * 把內容寫入excel文件中
	 * 
	 * @param fileName
	 *            要寫入的文件的名稱
	 */
	public static void writeExcel(String fileName) {
		WritableWorkbook wwb = null;
		try {
			// 首先要使用Workbook类的工厂方法创建一个可写入的工作薄(Workbook)对象
			wwb = Workbook.createWorkbook(new File(fileName));
		} catch (IOException e) {
			e.printStackTrace();
		}
		if (wwb != null) {
			// 创建一个可写入的工作表
			// Workbook的createSheet方法有两个参数,第一个是工作表的名称,第二个是工作表在工作薄中的位置
			WritableSheet ws = wwb.createSheet("sheet1", 0);

			// 下面开始添加单元格
			for (int i = 0; i < 10; i++) {
				for (int j = 0; j < 5; j++) {
					// 这里需要注意的是,在Excel中,第一个参数表示列,第二个表示行
					Label labelC = new Label(j, i, "这是第" + (i + 1) + "行,第"
							+ (j + 1) + "列");
					try {
						// 将生成的单元格添加到工作表中
						ws.addCell(labelC);
					} catch (RowsExceededException e) {
						e.printStackTrace();
					} catch (WriteException e) {
						e.printStackTrace();
					}

				}
			}

			try {
				// 从内存中写入文件中
				wwb.write();
				// 关闭资源,释放内存
				wwb.close();
			} catch (IOException e) {
				e.printStackTrace();
			} catch (WriteException e) {
				e.printStackTrace();
			}
		}
	}

}
也没有什么难的,都是别人写好的类和方法,我们只需要调用进行了,此处省略控制excel表格样式的代码,自己需要什么样式的可以查看Api
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值