java操控easyexcel读取excel表格数据为null或部分字段为null

 数据部分字段null或者全部null:

java操控easyexcel读取excel表格数据为null或部分字段为null_第1张图片

可以看到很多字段出现null,解决办法很简单如下:

一、实体类中需要添加toString方法(快捷生成toString键:Ctrl+Ins)

   @Override
    public String toString() {
        return "DemoDate{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", Day='" + Day + '\'' +
                ", Time='" + Time + '\'' +
                '}';

二、实体类中的字段名开头不能为大写字母

java操控easyexcel读取excel表格数据为null或部分字段为null_第2张图片

完整代码如下:

        项目结构

java操控easyexcel读取excel表格数据为null或部分字段为null_第3张图片

这是我需要读取的Excel 表格文件

java操控easyexcel读取excel表格数据为null或部分字段为null_第4张图片

 这是我的pom.xml文件




  4.0.0

  org.example
  Demo2
  1.0-SNAPSHOT

  Demo2
  
  http://www.example.com

  
    UTF-8
    1.7
    1.7
  

  
    
      junit
      junit
      4.11
      test
    

    
    
      com.alibaba
      easyexcel
      2.2.3
    
  


这是实体类DemmoDate

package com.tom.domain;

import com.alibaba.excel.annotation.ExcelProperty;
import com.alibaba.excel.metadata.BaseRowModel;

/*
                            实体类
用来盛装Excel中读取的数据,数据模板类
 */
public class DemoDate  {
    //绑定excel表格头,value是字段名,index是字段个数从零开始
    @ExcelProperty(value = "编号",index = 0)
    private int id;

    @ExcelProperty(value = "姓名",index = 1)
    private String name;

    @ExcelProperty(value = "周数",index = 2)
    private String day;

    @ExcelProperty(value = "节数",index = 3)
    private String time;

    public DemoDate() {
    }

    public DemoDate(int id, String name, String day, String time) {
        this.id = id;
        this.name = name;
         this.day = day;
        this.time = time;
    }

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getDay() {
        return day;
    }

    public void setDay(String day) {
        this.day = day;
    }

    public String getTime() {
        return time;
    }

    public void setTime(String time) {
        this.time = time;
    }

    @Override
    public String toString() {
        return "DemoDate{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", Day='" + day + '\'' +
                ", Time='" + time + '\'' +
                '}';
    }
}

这是测试类

package com.tom.test;

import com.alibaba.excel.EasyExcel;
import com.alibaba.excel.context.AnalysisContext;
import com.alibaba.excel.event.AnalysisEventListener;
import com.tom.domain.DemoDate;
import org.junit.Test;

/*
读取操作单元测试
 */
public class ReadTest {
    @Test
    public void test01() {
        //读取Excel文件位置
        EasyExcel.read("D:\\测试表格.xlsx", DemoDate.class, new AnalysisEventListener() {

              // 每解析一行数据调用一次此处方法
            @Override
            public void invoke(DemoDate Date, AnalysisContext analysisContext) {

                System.out.println("解析的数据为:"+Date.toString());

                //调用数据库将解析完成的数据保存到数据库
            }
                 //当全部解析完被调用,这里还可以书写导入数据库的sql语句
            @Override
            public void doAfterAllAnalysed(AnalysisContext analysisContext) {
                System.out.println("-----解析完成-----");
            }
        }).sheet().doRead();
        
    }
}

运行结果:java操控easyexcel读取excel表格数据为null或部分字段为null_第5张图片

你可能感兴趣的:(easyexcel,java,java,大数据,数据仓库)