zoukankan      html  css  js  c++  java
  • poi导入导出

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

    解析xls: 

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



    解析xlsx: 

    Java代码  收藏代码
      1. package xlsx;  
      2.   
      3. import java.io.IOException;  
      4. import org.apache.poi.xssf.usermodel.XSSFCell;  
      5. import org.apache.poi.xssf.usermodel.XSSFRow;  
      6. import org.apache.poi.xssf.usermodel.XSSFSheet;  
      7. import org.apache.poi.xssf.usermodel.XSSFWorkbook;  
      8.   
      9. public class XlsxMain {  
      10.   
      11.   public static void main( String[] args) throws IOException {  
      12.     XlsxMain xlsxMain = new XlsxMain();  
      13.       
      14.     xlsxMain.readXlsx();  
      15.   }  
      16.   
      17.   private void readXlsx() throws IOException{  
      18.     String fileName = "D:\excel\xlsx_test.xlsx";  
      19.     XSSFWorkbook xssfWorkbook = new XSSFWorkbook( fileName);  
      20.       
      21.     // 循环工作表Sheet  
      22.     for(int numSheet = 0; numSheet < xssfWorkbook.getNumberOfSheets(); numSheet++){  
      23.       XSSFSheet xssfSheet = xssfWorkbook.getSheetAt( numSheet);  
      24.       if(xssfSheet == null){  
      25.         continue;  
      26.       }  
      27.         
      28.       // 循环行Row   
      29.       for(int rowNum = 0; rowNum <= xssfSheet.getLastRowNum(); rowNum++ ){  
      30.         XSSFRow xssfRow = xssfSheet.getRow( rowNum);  
      31.         if(xssfRow == null){  
      32.           continue;  
      33.         }  
      34.           
      35.         // 循环列Cell     
      36.         for(int cellNum = 0; cellNum <= xssfRow.getLastCellNum(); cellNum++){  
      37.           XSSFCell xssfCell = xssfRow.getCell( cellNum);  
      38.           if(xssfCell == null){  
      39.             continue;  
      40.           }  
      41.           System.out.print("   "+getValue(xssfCell));  
      42.         }  
      43.         System.out.println();  
      44.       }  
      45.     }  
      46.   }  
      47.     
      48.   @SuppressWarnings("static-access")  
      49.   private String getValue(XSSFCell xssfCell){  
      50.     if(xssfCell.getCellType() == xssfCell.CELL_TYPE_BOOLEAN){  
      51.       return String.valueOf( xssfCell.getBooleanCellValue());  
      52.     }else if(xssfCell.getCellType() == xssfCell.CELL_TYPE_NUMERIC){  
      53.       return String.valueOf( xssfCell.getNumericCellValue());  
      54.     }else{  
      55.       return String.valueOf( xssfCell.getStringCellValue());  
      56.     }  
      57.   }  
      58.     
      59. }  
  • 相关阅读:
    大并发服务器框架设计
    Flask框架(五) —— session源码分析
    Flask框架(三)—— 请求扩展、中间件、蓝图、session源码分析
    Flask框架(二)—— 反向解析、配置信息、路由系统、模板、请求响应、闪现、session
    Flask框架(一)—— Flask简介
    celery执行异步任务和定时任务
    爬虫(五)—— selenium模块启动浏览器自动化测试
    爬虫(四)—— 使用pyecharts展示数据
    爬虫(三)—— BeautifulSoup模块获取元素
    数据库(三)—— 数据库存储引擎、日志、备份、主从复制、高可用架构
  • 原文地址:https://www.cnblogs.com/cunkouzh/p/5015542.html
Copyright © 2011-2022 走看看