【esaypoi】esaypoi 使用

需求是这样的: 我们线上有些数据存在不一致的情况,leader 给了我一张 excel 表格, 叫我对比表格,写出更新的 sql 。

刚开始,我觉得也没有什么,打开表格就开始复制粘贴,查询起来。

但是做到一半,猛然觉得身为程序员却做这么多重复的工作简直就是一种耻辱。

于是乎,写了一个小demo,自动生成 sql 文件。

第一步,maven 依赖

复制代码
    <dependency>
        <groupId>cn.afterturn</groupId>
        <artifactId>easypoi-base</artifactId>
        <version>3.0.3</version>
    </dependency>
    <dependency>
        <groupId>cn.afterturn</groupId>
        <artifactId>easypoi-web</artifactId>
        <version>3.0.3</version>
    </dependency>
    <dependency>
        <groupId>cn.afterturn</groupId>
        <artifactId>easypoi-annotation</artifactId>
        <version>3.0.3</version>
    </dependency>
复制代码

 

第二步,定义pojo

比如我的表格样式是这样的

我定义的dto就是下面这样的

复制代码
@Data
public class PreTypeDTO {
    @Excel(name = "id", orderNum = "0")
    private String id;
    @Excel(name = "typeName", orderNum = "1")
    private String typeName;
    @Excel(name = "parentId", orderNum = "2")
    private String parentId;
    @Excel(name = "type", orderNum = "3")
    private String type;
    @Excel(name = "opStatus", orderNum = "4")
    private String opStatus;
}
复制代码

 

第三步, 愉快地使用

以将 excel 中的数据转化为 list 对象为例,

具体的实现可以这样写

复制代码
public static <E> List<E> import2List(String path, Class<?> pojoClass,ImportParams importParams){
    List<E> result = null;
    FileInputStream inputStream = null;
    try {
        inputStream = new FileInputStream(path);
    }catch (IOException e){
        log.error("read path error.");
        log.error(e.getMessage(), e);
        return new LinkedList<>();
    }
    
    try {
        result =  ExcelImportUtil.importExcel(inputStream, pojoClass, importParams);
    }catch (Exception e){
        log.error("importExcel error.");
        log.error(e.getMessage(), e);
        return new LinkedList<>();
    }

    try {
        if(Objects.nonNull(inputStream)){
            inputStream.close();
        }
    }catch (IOException e){
        log.error("close inputStream error.");
        log.error(e.getMessage(), e);
        return new LinkedList<>();
    }

    return result;
}
复制代码

比如将 list 对象导出到 excel 中。

复制代码
public static <E> String list2Excel(List<E> list, Class<E> clazz, String path){
    ExportParams exportParams = new ExportParams();
    exportParams.setSheetName("sheet1");
    Workbook workbook = ExcelExportUtil.exportExcel(exportParams, clazz, list);
    File file = FileUtils.createNewFile(path);
    FileOutputStream out = null;
    try{
        out = new FileOutputStream(file);
        workbook.write(out);
    }catch (IOException e){
        log.error(e.getMessage(), e);
    }

    try {
        if(null != out){
            out.close();
        }
    }catch (IOException e){
        log.error(e.getMessage(),e);
    }
    return path;
}
复制代码

 

 

 

posted @   猫咪大王_lkb  阅读(240)  评论(0编辑  收藏  举报
编辑推荐:
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· 使用C#创建一个MCP客户端
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
点击右上角即可分享
微信分享提示