excel文件导入或导出Java代码示例

1、excel文件导入

controller层接口内容

 service层代码

 

 serviceImpl内代码内容

 @Override
    @Transactional(rollbackFor = Exception.class)
    public void importCheckItemExcel(MultipartFile file, Long checkPkgId) throws Exception {
        if (file.isEmpty()){
            throw new IOException("请选择上传文件");
        }
        Workbook work = this.getWorkbook(file);
        if (null == work) {
            throw new HolliException(DeviceExceptionEnum.EXCEL_IS_NULL_EXCEPTION);
        }
        Iterator<Sheet> sheetIterator = work.sheetIterator();
        while (sheetIterator.hasNext()) {
            Sheet sheet = sheetIterator.next();
            if (sheet == null) {
                return;
            }
            //先获取首列标题
            Map<String, Integer> validColumns = new HashMap<>();
            List<String> headerCells = getFirstRow(sheet, 0);
            if (headerCells == null) {
                return;
            }
            for (int i = 0; i < headerCells.size(); i++) {
                Object header = headerCells.get(i);
                if (header == null) {
                    continue;
                }
                if (ObjectUtil.contains(header, "修程")) {
//                    validColumns.put("checkLevel", i);//数字
                    validColumns.put("checkLevelName", i);//含义
                }else if (ObjectUtil.contains(header, "工作项目")) {
                    validColumns.put("checkName", i);
                }else if (ObjectUtil.contains(header, "单位")) {
//                    validColumns.put("checkUnit", i);//数字
                    validColumns.put("checkUnitName", i);//含义
                }else if (ObjectUtil.contains(header, "周期")) {
                    validColumns.put("checkCycle", i);
                }else if (ObjectUtil.contains(header, "工作内容及标准")) {
                    validColumns.put("checkContent", i);
                }else if (ObjectUtil.contains(header, "ATP型号")) {
                    validColumns.put("atpModel", i);
                }
            }
//标题集合
            if (validColumns.size() == 0) {
                return;
            }
            Map<String, Object> map = new HashMap<String, Object>();
            //遍历当前sheet中的所有行
            //包涵头部,所以要小于等于最后一列数,这里也可以在初始值加上头部行数,以便跳过头部
            for (int j = 1; j <= sheet.getLastRowNum(); j++) {
                //读取一行
                List<Object> rows = getRow(sheet, j);
                if (rows == null) {
                    continue;
                }
                Set<String> keySet = validColumns.keySet();
                for (String key : keySet) {
                    int col_index = validColumns.get(key);
                    if (col_index >= rows.size()) {
                        continue;
                    }
                    Object cell = rows.get(col_index);
                    map.put(key, cell);
                }
//取出对应属性及值内容 以便存储数据库
 //业务逻辑,数据存储
                DevCheckItemVo devCheckItemVo = new DevCheckItemVo();
                BeanUtil.copyProperties(map, devCheckItemVo);
                this.insertDevCheckItem(checkPkgId, devCheckItemVo, j + 1);
            }
        }
    }


 判断excel的格式,同时兼容2003和2007


    protected final static String excel2003L = ".xls";    //2003- 版本的excel
    protected final static String excel2007U = ".xlsx";   //2007+ 版本的excel
 

/**
     * 描述:根据文件后缀,自适应上传文件的版本
     */
    public static Workbook getWorkbook(MultipartFile file) throws Exception {
        Workbook wb = null;
        InputStream is = file.getInputStream();
        String fileType = file.getOriginalFilename().substring(file.getOriginalFilename().lastIndexOf("."));
        if (excel2003L.equals(fileType)) {
            wb = new XSSFWorkbook(is);  //2007+
//            因HSSFWorkbook报(You need to call a different part of POI to process this data (eg XSSF instead of HSSF)),故直接使用XSSFWorkbook处理
//            wb = new HSSFWorkbook(is);  //2003-
        } else if (excel2007U.equals(fileType)) {
            wb = new XSSFWorkbook(is);  //2007+
        } else {
            throw new IOException("解析的文件格式有误!");
        }
        return wb;
    }

 获取行数据

/**
     * 获取行数据
     * @param sheet
     * @param rowIndex
     * @return
     */
    public List<Object> getRow(Sheet sheet, int rowIndex) {
        List<Object> li = new ArrayList<Object>();
        if (sheet == null) {
            return null;
        }
        Row row = null;
        Cell cell = null;
        //读取一行
        row = sheet.getRow(rowIndex);
        //去掉空行和表头
        if (row == null) {
            return null;
        }
        /**为去掉空行,若第一列为空,则直接跳过该行*/
        if (ObjectUtil.isEmpty(row.getCell(0))) {
            return null;
        }
        //遍历所有的列
        for (int y = row.getFirstCellNum(); y < row.getLastCellNum(); y++) {
            cell = row.getCell(y);
            li.add(this.getCellFormatValue(cell));

        }
        return li;
    }

 //获取excel列表内的对应数据格式


//获取excel列表内的对应数据格式
    protected Object getCellFormatValue(Cell cell) {
        Object val = "";
        if (null != cell) {
            if (cell.getCellType() == CellType.NUMERIC || cell.getCellType() == CellType.FORMULA)
            {
                val = cell.getNumericCellValue();
                if (DateUtil.isCellDateFormatted(cell))
                {
                    val = DateUtil.getJavaDate((Double) val); // POI Excel 日期格式转换
                }
                else
                {
                    if ((Double) val % 1 != 0)
                    {
                        val = new BigDecimal(val.toString());
                    }
                    else
                    {
                        val = new DecimalFormat("0").format(val);
                    }
                }
            }
            else if (cell.getCellType() == CellType.STRING)
            {
                val = cell.getStringCellValue();
            }
            else if (cell.getCellType() == CellType.BOOLEAN)
            {
                val = cell.getBooleanCellValue();
            }
            else if (cell.getCellType() == CellType.ERROR)
            {
                val = cell.getErrorCellValue();
            }
        } else {
            val = "";
        }
        return val;
    }

 2、excel导出

controller层接口内容

  service层代码

  serviceImpl内代码内容

 @Override
    public void exportCheckItemExcel(String strIds, HttpServletResponse response) throws Exception {
        List<DevCheckItem> devCheckItemList = new ArrayList<>();
        long[] itemIdArray = StrUtil.splitToLong(strIds,",");
        //查询检修项id
        for (int i = 0; i< itemIdArray.length; i++){
            DevCheckItem devCheckItem = this.getById(itemIdArray[i]);
            if (ObjectUtil.isNotEmpty(devCheckItem)){
                devCheckItemList.add(devCheckItem);
            }
        }
        if (ObjectUtil.isNotEmpty(devCheckItemList) && devCheckItemList.size() > 0){
            //导出excel
            XSSFWorkbook workbook=new XSSFWorkbook();
            //获得名字为sheet的工作本对象,这个是看你的模板工作表的名字
            XSSFSheet sheet = workbook.createSheet("sheet1");
            // 序号
            int serialNo = 1;
            //行号
            int rowIndex = 1;

            //创建表头
            XSSFRow row_excel = sheet.createRow(0);

//行业务数据填充
            XSSFCell cell = row_excel.createCell(0);
            cell.setCellValue("序号");

            cell = row_excel.createCell(1);
            cell.setCellValue("ATP型号");

            cell = row_excel.createCell(2);
            cell.setCellValue("修程");

            cell = row_excel.createCell(3);
            cell.setCellValue("工作项目");

            cell = row_excel.createCell(4);
            cell.setCellValue("单位");

            cell = row_excel.createCell(5);
            cell.setCellValue("周期(小时)");

            cell = row_excel.createCell(6);
            cell.setCellValue("工作内容及标准");

            //遍历填充数据
            for (DevCheckItem devCheckItem : devCheckItemList){
                //获取当前行
                row_excel = sheet.getRow(rowIndex);
                if (row_excel == null){
                    //创建行
                    row_excel = sheet.createRow(rowIndex);
                }
                //内容填充
                if (ObjectUtil.isNotEmpty(devCheckItem)){
                    XSSFCell cellNew = row_excel.createCell(0);
                    cellNew.setCellValue(serialNo);

                    cell = row_excel.createCell(1);
                    if (ObjectUtil.isNotEmpty(devCheckItem.getAtpModel())){
                        cell.setCellValue(devCheckItem.getAtpModel());
                    }

                    cell = row_excel.createCell(2);
                    if (ObjectUtil.isNotEmpty(devCheckItem.getCheckLevel())){
                        String levelName = DevCheckLevelEnum.getLevelNameByType(devCheckItem.getCheckLevel());
                        cell.setCellValue(levelName);
                    }

                    cell = row_excel.createCell(3);
                    if (ObjectUtil.isNotEmpty(devCheckItem.getCheckName())){
                        cell.setCellValue(devCheckItem.getCheckName());
                    }

                    cell = row_excel.createCell(4);
                    if (ObjectUtil.isNotEmpty(devCheckItem.getCheckUnit())){
                        String checkUnit = this.getCheckUnitNameByNum(devCheckItem.getCheckUnit());
                        cell.setCellValue(checkUnit);
                    }

                    cell = row_excel.createCell(5);
                    if (ObjectUtil.isNotEmpty(devCheckItem.getCheckCycle())){
                        cell.setCellValue(devCheckItem.getCheckCycle());
                    }

                    cell = row_excel.createCell(6);
                    if (ObjectUtil.isNotEmpty(devCheckItem.getCheckContent())){
                        cell.setCellValue(devCheckItem.getCheckContent());
                    }
                }
                serialNo++;
                rowIndex++;
            }
            response.setCharacterEncoding("UTF-8");
            response.setHeader("Content-Type", "application/vnd.ms-excel");
            ServletOutputStream out = response.getOutputStream();
            workbook.write(out);

        }
    }

以上已导出完成。

3、以下为可能会用到的导出实例文件,上传文件服务器的过程 

File格式转换MultipartFile格式的例子

//上传minio服务器
String fileName = "检修工作项目.xlsx";
File cacheFile = new File(fileName);
if (cacheFile.exists()) {
    cacheFile.delete();
}
  
cacheFile.createNewFile();//生成文件
OutputStream out = new FileOutputStream(cacheFile);
workbook.write(out);
---------------------------------------------------------------------------------------(上面为导出实例文件)
//下面为上传文件流格式转换的格式。
FileInputStream fileInputStream = new FileInputStream(cacheFile);
MultipartFile multipartFile = new MockMultipartFile("cacheFile", cacheFile.getName(), "text/plain", IOUtils.toByteArray(fileInputStream));

 

-------------------------------------以下无正文-----------------------------------------------------------

注:仅供学习,记录问题和参考,共勉!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/40654.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

使用WebRTC实现多人视频会议

1.初步准备 1.1.使用同事nodejs开发的一个信令服务器。提供Https的WebSocket功能 1.2.准备一个多人视频会议的客户端Web程序client.html 2.遇到问题 2.1.在Tomcat下打开client.html&#xff0c;如果不使用http://127.0.0.1:8081/vedio/client.html&#xff0c;而使用实际IP…

uni-app实现emoj表情包发送(nvue版)

uni-app实现表情包发送&#xff0c; vue实现思路直接使用grideview网格布局加载emoj表情包即可实现&#xff0c;很简单&#xff0c;但是nvue稍微复杂&#xff0c;这里采用的方案是nvue提供的组件list 看效果 代码 <template><view style"margin-right: 10rpx;m…

Golang跨平台UI框架之Wails(二)

上一篇文章我们讲解了如何简单创建一个 wails 的项目,但是现在有很多前端框架我们可以选择,比如: AngularVueSvelteReactLitVanilla各个都是时代的弄潮儿,就看哪一个适合你了,后续的系列都是以Angular为例。 1. 创建Angular模板项目 由于 wails 是没有官方支持Angular的…

浅谈自动化测试工具 Appium

目录 前言&#xff1a; 一、简单介绍 &#xff08;一&#xff09;测试对象 &#xff08;二&#xff09;支持平台及语言 &#xff08;三&#xff09;工作原理 &#xff08;四&#xff09;安装工具 二、环境搭建 &#xff08;一&#xff09;安装 Android SDK &#xff0…

uniapp自定义头部,计算状态栏和导航栏高度超简单三步

效果图 1.pages.json 页面给要自定义头部的页面加入一行代码 "navigationStyle":"custom" {"path": "pages/index/index","style": {"navigationBarTitleText": "","navigationStyle":"…

Redis 读写分离 使用redisTemplate执行lua脚本时,报错处理

项目框架说明 项目配置 <parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.5.4</version></parent>....<dependency><groupId>org.springfra…

MySQL内置函数

内置函数从实现的功能角度可以分为数值函数、字符串函数、日期和时间函数、流程控制函数、加密与解密函数&#xff0c;获取MySQL信息函数、聚合函数等。 1.数值函数 来源&#xff1a; 版权声明&#xff1a;本文为CSDN博主「清风拂来水波不兴」的原创文章&#xff0c;遵循CC 4…

带记忆的Transformer模块

MEMORIZING TRANSFORMERS 返回论文和资料目录 论文地址 1.导读 谷歌去年做的一个工作。内容很简单&#xff0c;在Transformer模块中加入了一层记忆层&#xff0c;结果表明这个方法可以帮助模型提高在NLP任务上的表现&#xff1a;generic webtext (C4), math papers (arXiv),…

纯干货!!!Java后端技术清单(附图)

分享一份最新的Java后端开发技能清单&#xff0c;可根据自身情况以及岗位招聘要求做动态调整&#xff0c;核心思想就是尽可能满足岗位招聘的所有技能要求。 Java后端技术清单: 1.计算机基础:熟练掌握计算机网络、数据结构和算法、操作系统&#xff0c;了解计算机组成原理。 …

06_本地方法接口+07_本地方法栈

一、本地方法&#xff1f; 本地方法就是Java调用非Java代码的接口。 本地方法的作用是融合不同的编程语言为Java所用&#xff0c;它的初衷是融合 C、C程序 二、为什么要使用Native Method? 三、本地方法栈 Java虚拟机栈用于管理Java方法的调用&#xff0c;而本地方法栈用于…

PyCharm 常用快捷键

目录 1、代码编辑快捷键 2、搜索/替换快捷键 3、代码运行快捷键 4、代码调试快捷键 5、应用搜索快捷键 6、代码重构快捷键 7、动态模块快捷键 8、导航快捷键 9、通用快捷键 1、代码编辑快捷键 序号快捷键作用1CTRLALTSPACE快速导入任意类2CTRLSHIFTENTER代码补全3SHI…

nacos注册中心+Ribbon负载均衡+完成openfeign的调用(超详细步骤)

目录 1.注册中心 1.1.nacos注册中心 1.2. 微服务注册和拉取注册中心的内容 2.3.修改订单微服务的代码 3.负载均衡组件 3.1.什么是负载均衡 3.2.什么是Ribbon 3.3.Ribbon 的主要作用 3.4.Ribbon提供的负载均衡策略 4.openfeign完成服务调用 4.1.什么是OpenFeign 4.2…

第四章 云原生架构之Kubernetes基础知识

1、K8S整体架构 1.1、概述 ​ Kubernetes是一个可移植、可扩展的开源平台&#xff0c;用于管理容器化的工作负载和服务&#xff0c;简称 K8S。K8S的本质是一组服务器集群&#xff0c;可以在对应服务器集群的每个节点上运行程序&#xff0c;来对节点中的容器进行管理。类似Mas…

Mac怎么把mov转换成mp4?

mac怎么把mov转换成mp4&#xff1f;在我们准备转换之前&#xff0c;让我们先了解一下为什么要将MOV格式转换为MP4格式。MOV格式是美国苹果公司独立开发发布的视频文件格式&#xff0c;在Mac电脑以及苹果其它智能设备上播放效果非常出色。然而&#xff0c;如果您想与他人分享视频…

[JVM] 3. 类加载子系统(2)-- 类加载器、双亲委派机制(JDK1.8及之前)及其他

前言 JDK1.8及之前和JDK9及之后的双亲委派模型是不一样的&#xff0c;这里学习了1.8及以前的双亲委派模型&#xff0c;记录笔记 一、类加载器 1.8之前主要是这几种类加载器&#xff1a; 1. 启动类加载器(Bootstrap ClassLoader)&#xff1a; 负责将存放在<JAVA_HOME>…

浅谈设计模式之单例模式

0 单例模式简介 单例模式属于创建型模式&#xff0c;它提供了一种创建对象的最佳方式。单例模式指的是单一的一个类&#xff0c;该类负责创建自己的对象&#xff0c;并且保证该对象唯一。该类提供了一种访问其唯一对象的方法&#xff0c;外部需要调用该类的对象可以通过方法获…

HTPP入门教程||HTTP 状态码||HTTP content-type

HTTP 状态码 当浏览者访问一个网页时&#xff0c;浏览者的浏览器会向网页所在服务器发出请求。当浏览器接收并显示网页前&#xff0c;此网页所在的服务器会返回一个包含 HTTP 状态码的信息头&#xff08;server header&#xff09;用以响应浏览器的请求。 HTTP 状态码的英文为…

基于.net6的WPF程序使用SignalR进行通信

之前写的SignalR通信&#xff0c;是基于.net6api&#xff0c;BS和CS进行通信的。 .net6API使用SignalRvue3聊天WPF聊天_signalr wpf_故里2130的博客-CSDN博客 今天写一篇关于CS客户端的SignalR通信&#xff0c;后台服务使用.net6api 。其实和之前写的差不多&#xff0c;主要在…

基于html2canvas和jspdf将document DOM节点转换为图片生成PDF文件,并下载到本地

这里要用到html2canvas将document DOM节点转换为图片&#xff0c;并下载到本地_你挚爱的强哥的博客-CSDN博客前端用原生js编辑文件内容→创建生成文件(格式可以自定义)→下载文件_你挚爱的强哥的博客-CSDN博客。会自动创建一个html文件。https://blog.csdn.net/qq_37860634/art…

stb_image简单使用

简介stb_image stb_image 是一个非常轻量级的、单文件的图像加载库&#xff0c;用于加载和解码多种图像格式&#xff08;如BMP、JPEG、PNG、GIF等&#xff09;的图像数据。它由Sean T. Barrett开发&#xff0c;并以公共领域&#xff08;Public Domain&#xff09;许可发布&…
最新文章