1.、数据导入:减轻录入工作量
2、数据导出:统计信息归档
3、数据传输:异构系统之间数据传输
<dependencies>
<!-- https://mvnrepository.com/artifact/com.alibaba/easyexcel -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>easyexcel</artifactId>
<version>2.1.1</version>
</dependency>
</dependencies>
import com.alibaba.excel.EasyExcel;
import com.alibaba.excel.annotation.ExcelProperty;
import lombok.Data;
@Data
public class DemoData {
@ExcelProperty("学生编号")
private int sno;
@ExcelProperty("学生姓名")
private String sname;
}
public static void main(String[] args) {
String fileName = "xxx.xlsx";
EasyExcel.write(fileName,DemoData.class).sheet("sheetName").doWrite(data());
}
//循环设置要添加的数据,最终封装到list集合中
private static List<DemoData> data(){
ArrayList<DemoData> list = new ArrayList<>();
for (int i= 0;i<20;i++) {
DemoData data = new DemoData();
data.setSno(i);
data.setSname("法外狂徒"+i);
list.add(data);
}
return list;
}
import com.alibaba.excel.annotation.ExcelProperty;
import lombok.Data;
@Data
public class ReadData {
@ExcelProperty(index = 0)
private int sid;
@ExcelProperty(index = 1)
private String sname;
}
//创建读取excel监听器
public class ExcelListener extends AnalysisEventListener<ReadData> {
//创建list集合封装最终的数据
List<ReadData> list = new ArrayList<ReadData>();
//一行一行去读取excle内容
@Override
public void invoke(ReadData user, AnalysisContext analysisContext) {
System.out.println("***"+user);
list.add(user);
}
//读取excel表头信息
@Override
public void invokeHeadMap(Map<Integer, String> headMap, AnalysisContext
context) {
System.out.println("表头信息:"+headMap);
}
//读取完成后执行
@Override
public void doAfterAllAnalysed(AnalysisContext analysisContext) {
}
}
public static void main(String[] args) throws Exception {
//写法1:
String fileName = "F:\\01.xlsx";
//这里需要指定读用哪个class去读,然后读取第一个sheet 文件流会自动关闭
EasyExcel.read(fileName, ReadData.class, new
ExcelListener()).sheet().doRead();
// 写法2:
InputStream in = new BufferedInputStream(new
FileInputStream("F:\\01.xlsx"));
ExcelReader excelReader = EasyExcel.read(in, ReadData.class, new
ExcelListener()).build();
ReadSheet readSheet = EasyExcel.readSheet(0).build();
excelReader.read(readSheet);
// 这里千万别忘记关闭,读的时候会创建临时文件,到时磁盘会崩的
excelReader.finish();
}