Easypoi简化了开发中对文档的导入导出实现,并不像poi那样都要写大段工具类来搞定文档的读写。

第一步引入Easypoi依赖

cn.afterturn

easypoi-spring-boot-starter

4.2.0

Easypoi的注解使用说明(存留查看即可)

第二步定义对应表格头数据对象实体类(注解的使用可以查阅上面的按需使用即可)

@Setter

@Getter

@ToString

public class LoginCaseDto {

@Excel(name = "flag(0是反向,1是正向)",orderNum = "1",width = 20)

private String flag;

@Excel(name = "urlid(访问id)",orderNum = "2",width = 20)

private String urlid;

@Excel(name = "name(登录账号)",orderNum = "3",width = 20)

private String name;

@Excel(name = "pwd(登录密码)",orderNum = "4",width = 20)

private String pwd;

@Excel(name = "desc(期望提示语)",orderNum = "5",width = 40)

private String desc;

@Excel(name = "actual(实际测试结果)",orderNum = "6",width = 40 )

private String actual;

@Excel(name = "urlpath(被测路径)",orderNum = "7",width = 40 )

private String urlpath;

}

public class LoginUrlDto {

@Excel(name = "id(访问测试类型)",orderNum = "1",width = 20)

private String id;

@Excel(name = "type(请求类型)",orderNum = "2",width = 20)

private String type;

@Excel(name = "url(访问地址)",orderNum = "3",width = 40)

private String url;

}

第三步:封装Easypoi工具类(网上查了很多但是并不完整,这里补充下)

参考文章

关键封装工具类多sheet导入方法

/**

* 功能描述:根据接收的Excel文件来导入多个sheet,根据索引可返回一个集合

* @param filePath 导入文件路径

* @param sheetIndex 导入sheet索引

* @param titleRows 表标题的行数

* @param headerRows 表头行数

* @param pojoClass Excel实体类

* @return

*/

public static List importExcel(String filePath,int sheetIndex,Integer titleRows, Integer headerRows, Class pojoClass) {

// 根据file得到Workbook,主要是要根据这个对象获取,传过来的excel有几个sheet页

ImportParams params = new ImportParams();

// 第几个sheet页

params.setStartSheetIndex(sheetIndex);

params.setTitleRows(titleRows);

params.setHeadRows(headerRows);

List list = null;

try {

list = ExcelImportUtil.importExcel(new File(filePath), pojoClass, params);

} catch (NoSuchElementException e) {

throw new RuntimeException("模板不能为空");

} catch (Exception e) {

e.printStackTrace();

}

return list;

}

excel导入示例(直接传入sheet索引获取对应的sheet表)

多sheet表导出方法使用(需要把导入的多sheet表数据转成list集合获取新数据后调用该方法重新写入)

/**

* 功能描述:把同一个表格多个sheet测试结果重新输出,如果后续增加多个List>对象,需要后面继续追加

* @ExcelEntiry sheet表格映射的实体对象

* @return

*/

public static String exportSheet( Object...objects){

Workbook workBook = null;

try {

// 创建参数对象(用来设定excel得sheet得内容等信息)

ExportParams deptExportParams = new ExportParams();

// 设置sheet得名称

deptExportParams.setSheetName("登录用例");

// 设置sheet表头名称

deptExportParams.setTitle("测试用例");

// 创建sheet1使用得map

Map deptExportMap = new HashMap<>();

// title的参数为ExportParams类型,目前仅仅在ExportParams中设置了sheetName

deptExportMap.put("title", deptExportParams);

// 模版导出对应得实体类型

deptExportMap.put("entity", LoginCaseDto.class);

// sheet中要填充得数据

deptExportMap.put("data", objects[0]);

ExportParams empExportParams = new ExportParams();

empExportParams.setTitle("被测RUL路径");

empExportParams.setSheetName("被测url");

// 创建sheet2使用得map

Map empExportMap = new HashMap<>();

empExportMap.put("title", empExportParams);

empExportMap.put("entity", LoginUrlDto.class);

empExportMap.put("data", objects[1]);

// 将sheet1、sheet2使用得map进行包装

List> sheetsList = new ArrayList<>();

sheetsList.add(deptExportMap);

sheetsList.add(empExportMap);

// 执行方法

workBook = EasyPoiUtil.exportExcel(sheetsList, ExcelType.HSSF);

//String fileName = URLEncoder.encode("test", "UTF-8");

String filepath = (String) LoadStaticConfigUtil.getCommonYml( "testcaseexcel.cases");

FileOutputStream fos = new FileOutputStream(filepath);

workBook.write(fos);

fos.close();

}catch (Exception e){

e.printStackTrace();

}finally {

if(workBook != null) {

try {

workBook.close();

} catch (IOException e) {

e.printStackTrace();

}

}

}

return "success";

}

最后即可获取新的测试结果表格。

项目源码地址传送门

更多测试技术分享、学习资源以及一些其他福利可关注公众号:【Coding测试】获取:

easyexcel多个sheet导入_Easypoi实现excel多sheet表导入导出功能相关推荐

  1. java复制sheet_java-poi 复制Sheet到另一个excel的sheet中

    原题链接在这里:https://leetcode.com/problems/excel-sheet-column-number/ 这道题与Excel Sheet Column Title相呼应.Tim ...

  2. asp excel导入mysql_asp实现excel中的数据导入数据库

    asp实现excel中的数据导入数据库 wenjian = request.Form("select") '获取文件扩展名 ext = FileExec(wenjian) '判断文 ...

  3. 外部表如何导入mysql_如何利用Oracle外部表导入文本文件的数据

    Oracle外部表支持两种类型的驱动:一种是ORACLE_LOADER,外部表的数据必须来源于文件文件,另一种则是ORACLE_DATAPUMP,外部表的 同事最近在忙数据一致性比对工作,需要对不同文 ...

  4. 办公软件excel表格_国产表格神器:超脱excel,画表只是基本功能,做软件才是真本事...

    EXCEL真的可以放下了 纯中文的电子表格软件,让你配置模板更方便. 带定时提醒的表格软件,让你不再错漏忘工作. 还能做成APP的表格软件,让你不用开电脑也能工作. (文末有免费工具,自行下载即可) ...

  5. excel百万数据如何导入导出

    前景 在项目开发中往往需要使用到数据的导入和导出,导入就是从Excel中导入到DB中,而导出就是从DB中查询数据然后使用POI写到Excel上. 写本文的背景是因为在工作中遇到了大数据的导入和导出,问 ...

  6. 用ado把excel数据写入oracle,如何将excel表格数据导入到oracle数据库对应的表中?!oracle导出excel文件...

    如何把excel里的表导入到oracle里 使用第三方工具吧,toad之类的 一个excel表格中有多个sheet,如何将其导入oracle数据库 户和要用DBA 最简单得建用户: create us ...

  7. 22、NC导入数据至EXCEL

    ** 22.NC导入数据至EXCEL ** 代码:自定义按钮导出 package nc.ui.hfhr.hfhr_continefault.action;import java.awt.Compone ...

  8. Excel多sheet拆分

    Excel多sheet拆分 文章目录 Excel多sheet拆分 前言 实现方法 前言 由于一个Excel的sheet页过多,不方便查找对应资料,于是领导让我把sheet页拆分成单个Excel方便查找 ...

  9. ABAP Excel处理-内表导出为Excel文件

    目录 一.概述 二.内表导出为Excel文件的实现 1. OLE下载内表数据为Excel文件 2. DOI下载内表数据为Excel文件 3. 生成文本形式的Excel(.xls或.csv) 4. 标准 ...

最新文章

  1. YOLOv4中的tricks概念总结——Bag of freebies
  2. 【Groovy】json 字符串反序列化 ( 使用 JsonSlurper 进行 json 字符串反序列化 | 根据 map 集合构造相关类 )
  3. ActiveMQ消息优先级:工作原理
  4. tortoisesvn创建部署项目_FrameWork如何进行云托管部署
  5. php mysql读取数据查询_PHP MySQL 读取数据
  6. ansible软件部署
  7. 如何修改php的网页文件,php如何修改php文件内容
  8. Android Studio “Project Structure”选项目录结构显示异常
  9. struts2 返回html文本,Struts2 s:textfield文本示例
  10. 科学计算器java_科学计算器的Java实现
  11. 确定你的电脑是否支持安装64位操作系统
  12. STM32官方USB库下载指南
  13. Mysql插件HandlerSocket的应用
  14. VC++制作连连看辅助经验分享
  15. 王者荣耀服务器不稳定总是跳频,vivo iQOO Pro 5G手机打玩王者荣耀网络不稳定出现断流...
  16. ps -aux | grep xxx详解
  17. php正则判断数字和英文,PHP正则匹配中英文、数字及下划线的方法【用户名验证】...
  18. python文件怎么另存为_python+pywin32处理另存为弹出框保存文件
  19. 使用OpenCV检测摄像头视频中的人脸
  20. jmeter 之 配置jdbc环境

热门文章

  1. 性能翻倍!斯坦福Matei团队推出机器学习模型优化新方法
  2. 1.3 Shell脚本编程基础之条件测试
  3. 使用Hystrix守护应用(1)
  4. 李洪强和你一起学习前端之(9)规避脱标,CSS可见性,滑动门案例
  5. Redis应用实践:小红书海量Redis存储之道
  6. HTML5 Canvas游戏开发(二)高级功能
  7. [Js插件]使用JqueryUI的弹出框做一个“炫”的登录页面
  8. myeclipse/eclipse方法和类的自动注解
  9. [图形图像]一次光线追踪的尝试
  10. 软件以人为本1 - 序 - 写于上海2011 ScrumGathering会后