zoukankan      html  css  js  c++  java
  • 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 + " "); 
    59.                         } 
    60.                     } 
    61.                     sb.append(" "); 
    62.                 } 
    63.                 sb.append(" "); 
    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

    高质量的代码就是对程序自己最好的注释。当你打算要添加注释时,问问自己,“我如何能改进编码以至于根本不需要添加注释?”改进你的代码,然后才是用注释使它更清楚。
  • 相关阅读:
    Silverlight 之 断点调试
    Silverlight 之 浅析
    Silverlight 之 新建项目解析
    Silverlight 之 创建
    有关TCP和UDP 粘包 消息保护边界
    计算机网络杂项
    RTP
    如何取消Linux下,vi中显示的^M符号
    Linux下实现定时器Timer的几种方法
    UNIX网络编程——套接字选项
  • 原文地址:https://www.cnblogs.com/endy-blog/p/3612251.html
Copyright © 2011-2022 走看看