IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 开发测试 -> Excel数据批量导入导出(基础版) -> 正文阅读

[开发测试]Excel数据批量导入导出(基础版)

相信在web开发中,很多人都会遇到批量导入/导出的需求,下面就为大家介绍web开发中Excel中的导入导出


一、导入依赖

提示:以下是本篇文章正文内容,下面案例可供参考

 <dependency>
	     <groupId>com.alibaba</groupId>
	     <artifactId>easyexcel</artifactId>
	     <version>2.2.4</version>
 </dependency>

二、导入导出的模型数据

@Data
@ContentRowHeight(10) // 内容行的高度
@HeadRowHeight(15)// 标题行的高度
@ColumnWidth(20)// 每一列的宽度
public class OrderVO {
    @ExcelProperty({"订单表信息","id"}) //第一个值-标题
    private int id;
    @ExcelProperty({"订单表信息","订单号"})
    private String orderNo;
    @ExcelProperty({"订单表信息","货主id"})
    private int huoZuId;
    @ExcelProperty({"订单表信息","承运商id"})
    private int carryId;
    @ExcelProperty({"订单表信息","交易价格"})
    private BigDecimal money;
    @ExcelProperty({"订单表信息","起源地"})
    private String from;
    @ExcelProperty({"订单表信息","目的地"})
    private String to;
    @DateTimeFormat("yyyy-MM-dd HH:mm:ss")
    @ExcelProperty({"订单表信息","创建日期"})
    private Date gmtCreate;
    @DateTimeFormat("yyyy-MM-dd HH:mm:ss")
    @ExcelProperty({"订单表信息","修改日期"})
    private Date gmtUpdate;
}

三、Excel数据的导出

常用于批量导出,示例代码:

    @ApiOperation("下载订单")
    @GetMapping("/{num}/{size}")
    public void orderPage(@PathVariable("num") int pageNum, @PathVariable("size") int pageSize) throws IOException {
        PageHelper.startPage(pageNum,pageSize);
        // 通过业务层获取到的订单数据
        PageInfo<OrderVO> orderPages = new PageInfo(orderService.orderPage());
        ServletRequestAttributes servletRequestAttributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
        HttpServletResponse response = servletRequestAttributes.getResponse();
        response.setContentType("application/vnd.ms-excel");
        response.setCharacterEncoding("utf-8");
        response.setHeader("Content-disposition", "attachment;filename=demo.xlsx");
		// 将list数据根据OrderVO.class写入到文件流中,输出
        EasyExcel.write(response.getOutputStream(), OrderVO.class).sheet("表1").doWrite(orderPages.getList());
        return ;
    }

在这里插入图片描述

在这里插入图片描述

四、Excel数据的导入

常用在批量导入数据,示例代码:

    @ApiOperation("导入excel的数据到后端")
    @PostMapping("/export")
    public InfoResultVO export(MultipartFile file) throws IOException {
        final List<OrderVO> list = new ArrayList();
        // 参数一:读取的文件流
        // 参数二:读取sheet的一行,将参数封装在DemoData实体类中
    	// 参数三:读取每一行的时候会执行DemoDataListener监听器
        EasyExcel.read(file.getInputStream(), OrderVO.class, new AnalysisEventListener<OrderVO>() {
            @Override
            public void invoke(OrderVO data, AnalysisContext context) {
                log.info("解析每一条数据{}",data);
                list.add(data);
            }
            @Override
            public void doAfterAllAnalysed(AnalysisContext context) {
                log.info("解析完成{}",list);
            }
        }).sheet("表1").doRead();
        // 不写表名,默认读第一个
        return new InfoResultVO(200,null,"导入数据成功");
    }

在这里插入图片描述
在这里插入图片描述

总结

想要更进一步了解学习,参考阿里云链接:https://developer.aliyun.com/article/787306#slide-3
文章其实还存在个小问题,就是日期信息的导入导出不准确,还待优化

  开发测试 最新文章
pytest系列——allure之生成测试报告(Wind
某大厂软件测试岗一面笔试题+二面问答题面试
iperf 学习笔记
关于Python中使用selenium八大定位方法
【软件测试】为什么提升不了?8年测试总结再
软件测试复习
PHP笔记-Smarty模板引擎的使用
C++Test使用入门
【Java】单元测试
Net core 3.x 获取客户端地址
上一篇文章      下一篇文章      查看所有文章
加:2022-04-29 12:25:58  更:2022-04-29 12:26:19 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/17 22:21:43-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码