Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 9987|回复: 0

关于解决java读取excel文件遇空行抛空指针的问题 !

[复制链接]
  • TA的每日心情
    奋斗
    2024-11-24 15:47
  • 签到天数: 804 天

    [LV.10]以坛为家III

    2053

    主题

    2111

    帖子

    72万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    726782
    发表于 2021-4-14 14:16:35 | 显示全部楼层 |阅读模式

    关于解决java读取excel文件遇空行抛空指针的问题 !

     

    package exceRead;
    
    import java.io.File;
    import java.io.FileInputStream;
    import java.io.FileNotFoundException;
    import java.io.IOException;
    import java.text.DecimalFormat;
    
    import org.apache.poi.ss.usermodel.Cell;
    import org.apache.poi.ss.usermodel.DateUtil;
    import org.apache.poi.ss.usermodel.Row;
    import org.apache.poi.xssf.usermodel.XSSFCell;
    import org.apache.poi.xssf.usermodel.XSSFSheet;
    import org.apache.poi.xssf.usermodel.XSSFWorkbook;
    
    public class ExcleReadNullRow {
        public static void getType(XSSFCell cell) {
            switch (cell.getCellType()) {
            case Cell.CELL_TYPE_STRING:
                System.out.print(cell.getRichStringCellValue().getString() + "|");
                // System.out.print("|");
                break;
            case Cell.CELL_TYPE_NUMERIC:
                if (DateUtil.isCellDateFormatted(cell)) {
                    System.out.print(String.valueOf(cell.getDateCellValue()) + "|");
                } else {
                    System.out.print(cell.getNumericCellValue() + "|");
                }
                // System.out.print("|");
                break;
            case Cell.CELL_TYPE_BOOLEAN:
                System.out.print(cell.getBooleanCellValue() + "|");
                // System.out.print("|");
                break;
            default:
            }
    
        }
    
        public static void main(String[] args) throws FileNotFoundException, IOException {
    
            ExcleUtil excle = new ExcleUtil();
            String value = "";
            String filePath = "C:\\Users\\ty\\Documents\\工作簿1.xlsx";
            File file = new File(filePath);
            XSSFWorkbook wb = new XSSFWorkbook(new FileInputStream(file));
            XSSFSheet sheet = wb.getSheetAt(0);
            int rowcount = sheet.getLastRowNum() - sheet.getFirstRowNum();
            int rowcount1 = sheet.getPhysicalNumberOfRows();
            System.out.println(rowcount1);
            System.out.println("该excle的总行数为:" + (rowcount + 1) + "行 !");
    
            /*
             * int rows = sheet.getLastRowNum(); for(int i = 0; i < rows+1; i++){ //
             * List<String> rowData = new ArrayList<String>(); Row row =
             * sheet.getRow(i); if(row != null){ int cols = row.getLastCellNum();
             * for(int j = 0; j < cols; j++){ XSSFCell cell = (XSSFCell)
             * row.getCell(j); ExcleReadNullRow.getType(cell); } //
             * System.out.println();
             * 
             * }
             */
    
            for (int i = 0; i < rowcount + 1; i++) {
                Row row = sheet.getRow(i);
                if (row == null) {
                    System.out.println("this row is null ----------------------");
                    continue;
    
                } else {
                    for (int j = row.getFirstCellNum(); j < row.getLastCellNum(); j++) {
                        XSSFCell cell = (XSSFCell) row.getCell(j);
                        System.out.print("| ");
                        if (cell != null) {
                            ExcleReadNullRow.getType(cell);
                        } else {
    
                            continue;
    
                        }
                    }
                    System.out.println();
    
                }
    
            }
    
        }
    }

     

     

     

     

     

     

    excle文件中的内容 :

    java打印出出的内容 :

     

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2024-12-23 09:28 , Processed in 0.062066 second(s), 29 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表