java使用POI解析2007以上的Excel表格

来自http://hao0610.iteye.com/blog/1160678

使用poi来解析Excel的xls和xlsx。

解析xls:

Java代码  

  1. package xls;
  2. import java.io.FileInputStream;
  3. import java.io.IOException;
  4. import java.io.InputStream;
  5. import org.apache.poi.hssf.usermodel.HSSFCell;
  6. import org.apache.poi.hssf.usermodel.HSSFRow;
  7. import org.apache.poi.hssf.usermodel.HSSFSheet;
  8. import org.apache.poi.hssf.usermodel.HSSFWorkbook;
  9. public class XlsMain {
  10. public static void main( String[] args) throws IOException {
  11. XlsMain xlsMain = new XlsMain();
  12. xlsMain.readXls();
  13. }
  14. private void readXls() throws IOException{
  15. InputStream is = new FileInputStream( "D:\\excel\\xls_test2.xls");
  16. HSSFWorkbook hssfWorkbook = new HSSFWorkbook( is);
  17. // 循环工作表Sheet
  18. for(int numSheet = 0; numSheet < hssfWorkbook.getNumberOfSheets(); numSheet++){
  19. HSSFSheet hssfSheet = hssfWorkbook.getSheetAt( numSheet);
  20. if(hssfSheet == null){
  21. continue;
  22. }
  23. // 循环行Row
  24. for(int rowNum = 0; rowNum <= hssfSheet.getLastRowNum(); rowNum++){
  25. HSSFRow hssfRow = hssfSheet.getRow( rowNum);
  26. if(hssfRow == null){
  27. continue;
  28. }
  29. // 循环列Cell
  30. for(int cellNum = 0; cellNum <= hssfRow.getLastCellNum(); cellNum++){
  31. HSSFCell hssfCell = hssfRow.getCell( cellNum);
  32. if(hssfCell == null){
  33. continue;
  34. }
  35. System.out.print("    " + getValue( hssfCell));
  36. }
  37. System.out.println();
  38. }
  39. }
  40. }
  41. @SuppressWarnings("static-access")
  42. private String getValue(HSSFCell hssfCell){
  43. if(hssfCell.getCellType() == hssfCell.CELL_TYPE_BOOLEAN){
  44. return String.valueOf( hssfCell.getBooleanCellValue());
  45. }else if(hssfCell.getCellType() == hssfCell.CELL_TYPE_NUMERIC){
  46. return String.valueOf( hssfCell.getNumericCellValue());
  47. }else{
  48. return String.valueOf( hssfCell.getStringCellValue());
  49. }
  50. }
  51. }

解析xlsx:

Java代码  

    1. package xlsx;
    2. import java.io.IOException;
    3. import org.apache.poi.xssf.usermodel.XSSFCell;
    4. import org.apache.poi.xssf.usermodel.XSSFRow;
    5. import org.apache.poi.xssf.usermodel.XSSFSheet;
    6. import org.apache.poi.xssf.usermodel.XSSFWorkbook;
    7. public class XlsxMain {
    8. public static void main( String[] args) throws IOException {
    9. XlsxMain xlsxMain = new XlsxMain();
    10. xlsxMain.readXlsx();
    11. }
    12. private void readXlsx() throws IOException{
    13. String fileName = "D:\\excel\\xlsx_test.xlsx";
    14. XSSFWorkbook xssfWorkbook = new XSSFWorkbook( fileName);
    15. // 循环工作表Sheet
    16. for(int numSheet = 0; numSheet < xssfWorkbook.getNumberOfSheets(); numSheet++){
    17. XSSFSheet xssfSheet = xssfWorkbook.getSheetAt( numSheet);
    18. if(xssfSheet == null){
    19. continue;
    20. }
    21. // 循环行Row
    22. for(int rowNum = 0; rowNum <= xssfSheet.getLastRowNum(); rowNum++ ){
    23. XSSFRow xssfRow = xssfSheet.getRow( rowNum);
    24. if(xssfRow == null){
    25. continue;
    26. }
    27. // 循环列Cell
    28. for(int cellNum = 0; cellNum <= xssfRow.getLastCellNum(); cellNum++){
    29. XSSFCell xssfCell = xssfRow.getCell( cellNum);
    30. if(xssfCell == null){
    31. continue;
    32. }
    33. System.out.print("   "+getValue(xssfCell));
    34. }
    35. System.out.println();
    36. }
    37. }
    38. }
    39. @SuppressWarnings("static-access")
    40. private String getValue(XSSFCell xssfCell){
    41. if(xssfCell.getCellType() == xssfCell.CELL_TYPE_BOOLEAN){
    42. return String.valueOf( xssfCell.getBooleanCellValue());
    43. }else if(xssfCell.getCellType() == xssfCell.CELL_TYPE_NUMERIC){
    44. return String.valueOf( xssfCell.getNumericCellValue());
    45. }else{
    46. return String.valueOf( xssfCell.getStringCellValue());
    47. }
    48. }
    49. }

原文地址:https://www.cnblogs.com/yueguanguanyun/p/9065652.html

时间: 2024-09-28 15:05:08

java使用POI解析2007以上的Excel表格的相关文章

java使用poi包将数据写入Excel表格

1.Excel相关操作代码 1 import java.io.File; 2 import java.io.FileInputStream; 3 import java.io.FileNotFoundException; 4 import java.io.FileOutputStream; 5 import java.io.IOException; 6 import java.lang.reflect.Field; 7 import java.lang.reflect.Method; 8 imp

Java的poi技术读取和导入Excel

报表输出是Java应用开发中经常涉及的内容,而一般的报表往往缺乏通用性,不方便用户进行个性化编辑.Java程序由于其跨平台特性,不能直接操纵Excel.因此,本文探讨一下POI视线Java程序进行Excel的读取和导入. AD:WOT2014:用户标签系统与用户数据化运营培训专场 项目结构: 用到的Excel文件: XlsMain .java 类 //该类有main方法,主要负责运行程序,同时该类中也包含了用poi读取Excel(2003版) import java.io.FileInputSt

java 使用 poi 解析excel

背景: web应用经常需要上传文件,有时候需要解析出excel中的数据,如果excel的格式没有问题,那就可以直接解析数据入库. 工具选择: 目前jxl和poi可以解析excel,jxl很早就停止维护了,只支持excel-2003也就是xls格式的文件: poi可支持xls和xlsx格式的文件,经过考察,poi的功能强大很多,所以选择这个工具解析excel.文件上传在之前的一个专题有所提及. 需要如下jar包,jar包见附件,也可在官网下载. 注意: 1. 不支持单元格合并的情况,默认表格格式规

java使用poi解析或处理excel的时候,如何防止数字变成科学计数法的形式和其他常见Excel中数据转换问题

当使用POI处理excel的时候,遇到了比较长的数字,虽然excel里面设置该单元格是文本类型的,但是POI的cell的类型就会变成数字类型. 而且无论数字是否小数,使用cell.getNumbericCellValue() 去获取值的时候,会得到一个double,而且当长度大一点的时候会变成科学计数法形式. 那么获取这个单元格的原始的数据,就其实是一个double怎么转换成整数的问题了. 使用DecimalFormat对这个double进行了格式话,随后使用format方法获得的String就

Java 从数据库中查找信息导入Excel表格中

前端js function Excel (){ //ajax请求 $.ajax({ url : "outPutAboutShopInfo", type : "post", dataType : "json", data:{ "basicShop.shopId" : shopId, "basicShop.shopMemo" : stringType //不方便增加字段所以使用门店的一个"备注&quo

java利用poi解析excel文件

首先需要引入以下jar包 如果使用maven,需要添加两个依赖 <dependencies> <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi</artifactId> <version>3.15</version> </dependency> <dependency> <groupId>org.ap

Java用POI解析excel并获取所有单元格数据

1.导入POI相关jar包 org.apache.poi jar 2.代码示例 public List getAllExcel(File file, String tableName, String fname, String enterpriseId, String reportId, String projectId) throws FileNotFoundException, IOException, ClassNotFoundException, InstantiationExcepti

Java使用POI插件将数据以excel形式备份

将数据以表格形式进行备份 (1)导入poi的jar包 放入lib下:  WebRoot\WEB-INF\lib\poi-3.2-FINAL-20081019.jar (2)StringBuffer转换为二维数组 //定义一个StringBuffer,以 \r\n 分一维数组,以 \t 分二维数组 StringBuffer strff = new StringBuffer("姓名\t年龄\t性别\r\n小仙女\t18\t女\r\n"); //将StringBuffer数据转换为一维数组:

java的poi技术读,写Excel[2003-2007,2010]

position:static(静态定位) 当position属性定义为static时,可以将元素定义为静态位置,所谓静态位置就是各个元素在HTML文档流中应有的位置 podisition定位问题.所以当没有定义position属性时,并不说明该元素没有自己的位置,它会遵循默认显示为静态位置,在静态定位状态下无法通过坐标值(top,left,right,bottom)来改变它的位置. position:absolute(绝对定位) 当position属性定义为absolute时,元素会脱离文档流