当前位置: 首页 > news >正文

使用java poi解析表格

   @Test
    public void poi() throws Exception {
        InputStream inputStream=new FileInputStream("C:\\Users\\Administrator.SKY-20170602BKZ\\Desktop\\111.xlsx");
        //整个excel文件
        XSSFWorkbook xssfSheets = new XSSFWorkbook(inputStream);
        //每行的数据存一个list,然后每页的数据存到一个list
        List<List<String>> result=new ArrayList<List<String>>();
        //遍历XSSFWorkbook是否有多个sheet
        for (XSSFSheet xss:xssfSheets){
            //如果当前sheet为空则开始下一次循环
            if (xss==null)
                continue;
            //循环当前页 获取每一行
            for (int rowNum=1;rowNum<=xss.getLastRowNum();rowNum++){
                ArrayList<String> rowlist= new ArrayList<String>();
                XSSFRow row = xss.getRow(rowNum);
                short firstCellNum = row.getFirstCellNum();
                short lastCellNum = row.getLastCellNum();
                //获取每一个单元格
                Iterator<Cell> cellIterator = row.cellIterator();
                while (cellIterator.hasNext()){
                    Cell next = cellIterator.next();
                    next.setCellType(Cell.CELL_TYPE_STRING);
                    rowlist.add(next.getStringCellValue());
                }
                result.add(rowlist);
            }


        }
        System.out.println(result);




    }
解析代码

原文地址:https://m.aliyun.com/yunqi/articles/369813?spm=a2c41.11123433.0.0

如果poi导入excel表格数据时报出Cannot get a text value from a numeric cell错误

异常描述:在导入excel的时候在获取excel单元格数据的时候会出现Cannot get a text value from a numeric cell的异常抛出。

异常原因:poi读取excel单元格的数据,cell有不同的数据类型(CELL_TYPE_NUMERIC,CELL_TYPE_STRING,CELL_TYPE_FORMULA),如果cell中的数据是数值的话,如果你没有给他设置cell的类型的话。默认会认为是CELL_TYPE_NUMERICl类型,如果从一个NUMBER类型的Cell使用.cell.getStringCellValue()读取出一个字符串就会出错。

解决的方法:在读取数据之前,设置cell的类型为CELL_TYPE_STRING;

                         cell.setCellType(Cell.CELL_TYPE_STRING);

转载于:https://www.cnblogs.com/zqr99/p/8308849.html

相关文章:

  • 【Android】如何查看每个方法所花费的时间从而进行Performance的调优
  • docker-compose命令
  • 你还在迭代和递归吗?
  • 受欢迎的牛
  • appium自动化安装(一)
  • Template Method模板方法
  • UVA 10603 倒水问题
  • 程序员编程艺术第二十六章:基于给定的文档生成倒排索引(含源码下载)
  • Flume数据采集准备
  • 【Android】Menu不同菜单的使用介绍
  • python初识
  • Elasticsearch教程收集
  • 巧用Chrome格式化压缩后的js文件
  • 通过LoadBalancerClient获取所有服务列表的IP
  • HPUX Error 23 File table overflow
  • 【140天】尚学堂高淇Java300集视频精华笔记(86-87)
  • create-react-app做的留言板
  • CSS居中完全指南——构建CSS居中决策树
  • FineReport中如何实现自动滚屏效果
  • iOS 颜色设置看我就够了
  • Js实现点击查看全文(类似今日头条、知乎日报效果)
  • MD5加密原理解析及OC版原理实现
  • Objective-C 中关联引用的概念
  • PHP的Ev教程三(Periodic watcher)
  • Protobuf3语言指南
  • Python进阶细节
  • Spring Cloud(3) - 服务治理: Spring Cloud Eureka
  • SpringCloud(第 039 篇)链接Mysql数据库,通过JpaRepository编写数据库访问
  • vue.js框架原理浅析
  • vue和cordova项目整合打包,并实现vue调用android的相机的demo
  • 不用申请服务号就可以开发微信支付/支付宝/QQ钱包支付!附:直接可用的代码+demo...
  • 从伪并行的 Python 多线程说起
  • 大数据与云计算学习:数据分析(二)
  • 分布式事物理论与实践
  • 基于Mobx的多页面小程序的全局共享状态管理实践
  • 记一次和乔布斯合作最难忘的经历
  • 融云开发漫谈:你是否了解Go语言并发编程的第一要义?
  • 入门级的git使用指北
  • 应用生命周期终极 DevOps 工具包
  • 在Unity中实现一个简单的消息管理器
  • Android开发者必备:推荐一款助力开发的开源APP
  • Linux权限管理(week1_day5)--技术流ken
  • raise 与 raise ... from 的区别
  • 阿里云服务器如何修改远程端口?
  • 曜石科技宣布获得千万级天使轮投资,全方面布局电竞产业链 ...
  • ​html.parser --- 简单的 HTML 和 XHTML 解析器​
  • (2022 CVPR) Unbiased Teacher v2
  • (3)STL算法之搜索
  • (C++)八皇后问题
  • (C语言)二分查找 超详细
  • (MonoGame从入门到放弃-1) MonoGame环境搭建
  • (阿里巴巴 dubbo,有数据库,可执行 )dubbo zookeeper spring demo
  • (独孤九剑)--文件系统
  • (附源码)ssm旅游企业财务管理系统 毕业设计 102100
  • (三)终结任务