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

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

解析xls:

  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:

    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. }

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

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

    1.Excel相关操作代码 import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundExcept ...

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

    在上一篇blog:java的poi技术读取Excel[2003-2007,2010] 中介绍了关于java中的poi技术读取excel的相关操作 读取excel和MySQL相关: java的poi技术 ...

  3. java的poi技术读取和导入Excel实例

    本篇文章主要介绍了java的poi技术读取和导入Excel实例,报表输出是Java应用开发中经常涉及的内容,有需要的可以了解一下. 报表输出是Java应用开发中经常涉及的内容,而一般的报表往往缺乏通用 ...

  4. Java操作Jxl实现导出数据生成Excel表格数据文件

    实现:前台用的框架是Easyui+Bootstrap结合使用,需要引入相应的Js.Css文件.页面:Jsp.拦截请求:Servlet.逻辑处理:ClassBean.数据库:SQLserver. 注意: ...

  5. java 使用 poi 解析excel

    背景: web应用经常需要上传文件,有时候需要解析出excel中的数据,如果excel的格式没有问题,那就可以直接解析数据入库. 工具选择: 目前jxl和poi可以解析excel,jxl很早就停止维护 ...

  6. Java使用POI解析Excel表格

    概述 Excel表格是常用的数据存储工具,项目中经常会遇到导入Excel和导出Excel的功能. 常见的Excel格式有xls和xlsx.07版本以后主要以基于XML的压缩格式作为默认文件格式xlsx ...

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

    当使用POI处理excel的时候,遇到了比较长的数字,虽然excel里面设置该单元格是文本类型的,但是POI的cell的类型就会变成数字类型. 而且无论数字是否小数,使用cell.getNumberi ...

  8. 【Javaweb】poi实现通过上传excel表格批量导入数据到数据库

    1.导入poi相关jar包 对于只操作2003及以前版本的excel,只需要导入poi-XXX.jar ,如果还需要对2007及以后版本进行操作,则需要导入 poi-ooxml-XXX.jar poi ...

  9. java中poi解析excel(兼容07版本以上及以下:.xls和.xlsx格式)

    package com.genersoft.cbms.ysbz.ExcelDr.cmd; import com.genersoft.cbms.ysbz.ExcelDr.dao.ExcelDrDao; ...

随机推荐

  1. java--GC Root有哪些

    GC管理的主要区域是Java堆,一般情况下只针对堆进行垃圾回收.方法区.JVM栈和Native栈不被GC所管理,因而选择这些非堆区的对象作为GC roots,被GC roots引用的对象不被GC回收. ...

  2. 20165237 2017-2018-2 《Java程序设计》第十周考试补做及编程题

    20165237 2017-2018-2 <Java程序设计>第十周考试补做及编程题 知识点 1.链表是由若干个称作节点的对象组成的一种数据结构,每个节点含有一个数据和下一个节点的引用 . ...

  3. 关于 tp5.0 阿里云 oss 上传文件操作

    tp5.0 结合阿里云oss 上传文件 1.引入 oss 的空间( composer install 跑下第三方拓展包及核心代码包) 备注:本地测试无误,放到线上有问题  应该是移动后的路劲(相对于服 ...

  4. vsftp、ftps 搭建

    今天公司某个产品预上线,该产品需要向政府某部门提供一些数据. 该部门提交数据需要使用ftps,苦逼的我只能是测试环境搭建一套,用来测试提交数据. 先自行科普下ftps. 一.搭建vsftp 安装vsf ...

  5. Redis(转)

    传统MySQL+ Memcached架构遇到的问题 实际MySQL是适合进行海量数据存储的,通过Memcached将热点数据加载到cache,加速访问,很多公司都曾经使用过这样的架构,但随着业务数据量 ...

  6. Equivalent Sets HDU - 3836 2011多校I tarjan强连通分量

    题意: 给一些集合 要求证明所有集合是相同的 证明方法是,如果$A∈B$,$B∈A$那么$A=B$成立 每一次证明可以得出一个$X∈Y$ 现在已经证明一些$A∈B$成立 求,最少再证明多少次,就可以完 ...

  7. Unity3D游戏开发框架-资源管理类ResourceManage

    新建文件夹:ResMgr.接着新建三个C#脚本.代码如下: IResLoadListener.cs AssetInfo.cs ResMgr.cs using UnityEngine; using Sy ...

  8. Vue 指令篇 案例(输入提交显示 提交数据_列表)

    一.文本操作指令 //1.v-text <p v-text="msg"></p> 等价于 <p>{{msg}}</p> //2.v- ...

  9. python操作三大主流数据库(14)python操作redis之新闻项目实战②新闻数据的展示及修改、删除操作

    python操作三大主流数据库(14)python操作redis之新闻项目实战②新闻数据的展示及修改.删除操作 项目目录: ├── flask_redis_news.py ├── forms.py ├ ...

  10. MySQL配置说明

    以下内容,来源于http://www.jb51.net/article/48082.htm [client] port = 3306 socket = /tmp/mysql.sock [mysqld] ...