java操作excel进行导入导出

Java代码  icon_star

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

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

posted @ 2014-03-19 20:09  endy_zhu  阅读(285)  评论(0编辑  收藏  举报