easyexcel多个sheet导入_Easypoi实现excel多sheet表导入导出功能
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表导入导出功能相关推荐
- java复制sheet_java-poi 复制Sheet到另一个excel的sheet中
原题链接在这里:https://leetcode.com/problems/excel-sheet-column-number/ 这道题与Excel Sheet Column Title相呼应.Tim ...
- asp excel导入mysql_asp实现excel中的数据导入数据库
asp实现excel中的数据导入数据库 wenjian = request.Form("select") '获取文件扩展名 ext = FileExec(wenjian) '判断文 ...
- 外部表如何导入mysql_如何利用Oracle外部表导入文本文件的数据
Oracle外部表支持两种类型的驱动:一种是ORACLE_LOADER,外部表的数据必须来源于文件文件,另一种则是ORACLE_DATAPUMP,外部表的 同事最近在忙数据一致性比对工作,需要对不同文 ...
- 办公软件excel表格_国产表格神器:超脱excel,画表只是基本功能,做软件才是真本事...
EXCEL真的可以放下了 纯中文的电子表格软件,让你配置模板更方便. 带定时提醒的表格软件,让你不再错漏忘工作. 还能做成APP的表格软件,让你不用开电脑也能工作. (文末有免费工具,自行下载即可) ...
- excel百万数据如何导入导出
前景 在项目开发中往往需要使用到数据的导入和导出,导入就是从Excel中导入到DB中,而导出就是从DB中查询数据然后使用POI写到Excel上. 写本文的背景是因为在工作中遇到了大数据的导入和导出,问 ...
- 用ado把excel数据写入oracle,如何将excel表格数据导入到oracle数据库对应的表中?!oracle导出excel文件...
如何把excel里的表导入到oracle里 使用第三方工具吧,toad之类的 一个excel表格中有多个sheet,如何将其导入oracle数据库 户和要用DBA 最简单得建用户: create us ...
- 22、NC导入数据至EXCEL
** 22.NC导入数据至EXCEL ** 代码:自定义按钮导出 package nc.ui.hfhr.hfhr_continefault.action;import java.awt.Compone ...
- Excel多sheet拆分
Excel多sheet拆分 文章目录 Excel多sheet拆分 前言 实现方法 前言 由于一个Excel的sheet页过多,不方便查找对应资料,于是领导让我把sheet页拆分成单个Excel方便查找 ...
- ABAP Excel处理-内表导出为Excel文件
目录 一.概述 二.内表导出为Excel文件的实现 1. OLE下载内表数据为Excel文件 2. DOI下载内表数据为Excel文件 3. 生成文本形式的Excel(.xls或.csv) 4. 标准 ...
最新文章
- YOLOv4中的tricks概念总结——Bag of freebies
- 【Groovy】json 字符串反序列化 ( 使用 JsonSlurper 进行 json 字符串反序列化 | 根据 map 集合构造相关类 )
- ActiveMQ消息优先级:工作原理
- tortoisesvn创建部署项目_FrameWork如何进行云托管部署
- php mysql读取数据查询_PHP MySQL 读取数据
- ansible软件部署
- 如何修改php的网页文件,php如何修改php文件内容
- Android Studio “Project Structure”选项目录结构显示异常
- struts2 返回html文本,Struts2 s:textfield文本示例
- 科学计算器java_科学计算器的Java实现
- 确定你的电脑是否支持安装64位操作系统
- STM32官方USB库下载指南
- Mysql插件HandlerSocket的应用
- VC++制作连连看辅助经验分享
- 王者荣耀服务器不稳定总是跳频,vivo iQOO Pro 5G手机打玩王者荣耀网络不稳定出现断流...
- ps -aux | grep xxx详解
- php正则判断数字和英文,PHP正则匹配中英文、数字及下划线的方法【用户名验证】...
- python文件怎么另存为_python+pywin32处理另存为弹出框保存文件
- 使用OpenCV检测摄像头视频中的人脸
- jmeter 之 配置jdbc环境
热门文章
- 性能翻倍!斯坦福Matei团队推出机器学习模型优化新方法
- 1.3 Shell脚本编程基础之条件测试
- 使用Hystrix守护应用(1)
- 李洪强和你一起学习前端之(9)规避脱标,CSS可见性,滑动门案例
- Redis应用实践:小红书海量Redis存储之道
- HTML5 Canvas游戏开发(二)高级功能
- [Js插件]使用JqueryUI的弹出框做一个“炫”的登录页面
- myeclipse/eclipse方法和类的自动注解
- [图形图像]一次光线追踪的尝试
- 软件以人为本1 - 序 - 写于上海2011 ScrumGathering会后