java实现导入Excel数据入库

2023-05-16

java实现导入Excel数据入库

引入依赖

        <dependency>
            <groupId>jexcelapi</groupId>
            <artifactId>jxl</artifactId>
            <version>2.6</version>
        </dependency>

将Excel表格数据通过java导入到mysql数据库,废话不多说,直接上代码

如果导入失败,需要检查文件,另存为 97-2003版本的.xls

数据导入之后可以直接做其他业务操作

如果有错误的地方请指出,便于及时改正

package com.yihu.jw.base.endpoint.patient;

import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject;
import com.alibaba.fastjson.serializer.SerializerFeature;
import com.yihu.jw.entity.base.patient.BasePatientDO;
import com.yihu.jw.patient.dao.BasePatientDao;
import com.yihu.jw.restmodel.web.ObjEnvelop;
import com.yihu.jw.restmodel.web.endpoint.EnvelopRestEndpoint;
import com.yihu.jw.rm.base.BaseRequestMapping;
import com.yihu.utils.security.MD5;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiParam;
import jxl.Sheet;
import jxl.Workbook;
import org.apache.commons.lang.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;
import org.springframework.web.multipart.MultipartFile;

import javax.servlet.http.HttpServletRequest;
import java.io.InputStream;
import java.text.SimpleDateFormat;
import java.util.*;

/***
 * @ClassName: ImportExcelDemo
 * @Description:
 * @Auther:
 * @Date: 2021/9/14 13:45
 */
@RestController
@RequestMapping(value = BaseRequestMapping.BasePatient.PREFIX)
@Api(value = "数据导入", description = "数据导入", tags = {"数据导入"})
public class ImportExcelDemo extends EnvelopRestEndpoint {

    @Autowired
    private BasePatientDao basePatientDao;

    /**
     * 将表格数据导入到 base_patient 表
     *  如果添加失败,将Excel改成97-2003 xls版本
     * @param request
     * @param file
     * @return
     */
    @RequestMapping(value = "/importPatientFromExcel", produces = "application/json;charset=UTF-8",method = RequestMethod.POST)
    @ResponseBody
    public ObjEnvelop importPatientFromExcel(HttpServletRequest request, @ApiParam(value = "文件", required = true)
    @RequestParam(value = "file", required = true) MultipartFile file) {
        List errorLs = new ArrayList<>();
        List correctLs = new ArrayList<>();
        List idcardList = new ArrayList<>();
        Map<String, String> errorMsgMap = new HashMap<>();
        SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
        List<String> deviceCodes = new ArrayList<>();
        try {
            request.setCharacterEncoding("UTF-8");
            InputStream inputStream = file.getInputStream();
            Workbook rwb = Workbook.getWorkbook(inputStream);
            Sheet[] sheets = rwb.getSheets();
            int rows;
            int row;
            String name=null;//用户姓名
            String sex; //性别
            String age; //年龄
            String idcard;  //身份证号
            String mobile;  //联系方式
            String residentialArea; //居住小区
            String address; //居住地址
            String signTeam; //签约团队
            String label; //能力类型
            Sheet sheet = sheets[0];    //第一张表
            rows = sheet.getRows();
            for (int j = 1; j < rows; j++) {
                if (sheet.getRow(j).length == 0) {
                    continue;
                }
                BasePatientDO basePatientVO = new BasePatientDO();
                JSONObject infoMap = new JSONObject();
                row = j;
                name = sheet.getCell(0, row).getContents().trim();    //0 用户姓名
                sex = sheet.getCell(1, row).getContents().trim();  //1 性别
                age = sheet.getCell(2, row).getContents().trim();   //2 年龄
                idcard = sheet.getCell(3, row).getContents().trim(); //3 身份证号
                mobile = sheet.getCell(4, row).getContents().trim();  //4 联系方式
                residentialArea = sheet.getCell(5, row).getContents().trim(); //5 居住小区
                address = sheet.getCell(6, row).getContents().trim(); //6 居住地址
                signTeam = sheet.getCell(7, row).getContents().trim();; //签约团队
                label = sheet.getCell(8, row).getContents().trim();; //能力类型
                if (StringUtils.isBlank(idcard)){
                    continue;
                }
                if (StringUtils.isBlank(name)){
                    errorMsgMap.put(idcard,"姓名不能为空");
                    continue;
                }
                if (StringUtils.isBlank(sex)){
                    sex = "3";
                } else {
                    if (sex.equals("男")) {
                        sex = "1";
                    } else {
                        sex = "2";
                    }
                }
                if (StringUtils.isBlank(signTeam)){
                    errorMsgMap.put(idcard,"签约团队不能为空");
                    continue;
                }

                if (StringUtils.isBlank(label)){
                    errorMsgMap.put(idcard,"能力类型不能为空");
                    continue;
                }
                basePatientVO.setAddress(address);
                basePatientVO.setDel("1");
                basePatientVO.setIdcard(idcard);
                basePatientVO.setSex(new Integer(sex));
                basePatientVO.setName(name);
                basePatientVO.setMobile(mobile);
                basePatientVO.setArchiveStatus(3);
                basePatientVO.setArchiveType(1); //默认添加老人
                String pw = idcard.substring(idcard.length()-6);
                String salt = UUID.randomUUID().toString().substring(0,5);
                basePatientVO.setPassword(MD5.md5Hex(pw + "{" + salt + "}"));
                basePatientVO.setSalt(salt);
                basePatientVO.setId(getUID());
                infoMap.put("idcard",idcard);
                infoMap.put("signTeam",signTeam);
                infoMap.put("label",label);
                infoMap.put("patient",getUID());
                correctLs.add(basePatientVO);
                idcardList.add(infoMap);
            }

            basePatientDao.save(correctLs);

            //包装导入结果(导入成功数量、错误对象集合)
            Map<String, Object> map = new HashMap<>();
            map.put("successNum", correctLs.size());
            map.put("failedNum", rows-1 - correctLs.size() );
            map.put("errorData", JSON.toJSONString(errorMsgMap, SerializerFeature.WriteMapNullValue));
            System.out.println(map);
            return ObjEnvelop.getSuccess("获取成功",map);
        } catch (Exception e) {
            e.printStackTrace();
            return failedObjEnvelopException(e);
        }
    }



}

实体类代码就没必要上代码了,一张图

在这里插入图片描述

测试方式:postman进行测试

在这里插入图片描述

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

java实现导入Excel数据入库 的相关文章

随机推荐

  • formData传递数组

    在formData添加数组时 xff0c 会有一个的问题 xff0c 就是post请求会把数组拼接成一个字符串发送给服务器 这种时候有两种解决方案 一 后台拿到字符串后 xff0c 再通过截取字符串来生成数组 二 对数据进行字符串化 xff
  • 【面试】C/C++面试宝典一

    1 const 修饰变量 xff0c 说明该变量不可以被改变 xff1b 修饰指针 xff0c 分为指向常量的指针 xff08 pointer to const xff09 和自身是常量的指针 xff08 常量指针 xff0c const
  • vue3 + vite + ts + setup , 第十九练 vue3 中使用vue-router(三),动态路由

    动态路由 我们在做页面菜单权限的时候回用到动态路由来处理权限 xff0c 使用动态路由都是后台会返回一个路由表前端通过调接口拿到后处理 后端处理路由 动态路由主要通过两个函数实现 router addRoute 和 router remov
  • Android NestedScrollView 嵌套ViewPager不显示和出现空白部分 解决方法

    Android NestedScrollView 嵌套ViewPager不显示和出现空白部分 解决方法 问题分析 xff1a NestedScrollView里面只能有一个ViewGroup xff0c 也就是只允许有一个子节点 xff08
  • 组合导航(八):INS/GPS组合导航

    INS GPS组合导航1 误差反馈1 1 开环INS GPS架构1 2 闭环INS GPS架构 2 组合导航的类型2 1 松耦合 的INS GPS组合导航2 2 紧耦合 的INS GPS组合导航2 3 深度耦合的 INS GPS组合导航 3
  • 内网nginx代理到外网nginx(nginx之间的转发操作)

    nginx的基本常用命令 nginx t gt nginx刷新配置重启 nginx s reload 2 挂载信息查看 gt df h 挂载目录查看 etc nginx服务器之间的配置转发操作 最重要的部分 xff08 设置外层的nginx
  • 如何使用./ 执行和sh执行shell

    方法一 xff1a 给xxx sh文件加上可执行权限 chmod 指令加上可执行性权限 xff0c 然后直接使用 43 文件名 就可以运行 方法二 xff1a 直接使用 bin bash 43 文件名执行 方法三 xff1a 使用sh指令
  • Centos 7(1810)安装kubernetes单机版

    第一步 xff1a 基础网络配置 xff0c 需要能解析域名 1 部署一台CentOS虚拟机 xff0c 本次以最小化安装 xff01 2 配置基本的网络 xff0c 由于本次是最小化安装所以无法用命令行配置地址 命令行配置如下 xff1a
  • spring和springMVC配置文件中的扫描包如何配置

    我的项目大概文件路径 xff1a 然后进入主题 xff1a spring的配置文件名称为applicationContext xml springMVC的配置文件名称为dispatcherServlet servlet xml 1 spri
  • ESXi系统介绍及部署实战

    本文是向大家介绍ESXi系统部署 xff0c ESXi专为运行虚拟机 最大限度降低配置要求和简化部署而设计 只需几分钟时间 xff0c 客户便可完成从安装到运行虚拟机的全过程 一 ESXi简介 ESXi专为运行虚拟机 企业级虚拟化产品 xf
  • 一生产者多消费者模型 / 多生产者一消费者模型

    1 异常问题 xff08 wait问题 xff09 wait中断 xff1a 在调用处立即中断并且释放锁 xff0c 该线程转入等待队列 当收到持有同一把锁的线程notify通知后进入锁池队列 xff0c 再次获得同步锁之后才会继续执行 这
  • 磁共振处理软件Ubuntu->fsl安装

    经历了两天的时间 xff0c 终于在Ubuntu上安装了fsl 分享一下 xff01 xff01 xff01 所有资料 xff08 VW virtual box虚拟机 43 Ubuntu16 04 xff09 都在后面 xff0c 附链接
  • PyCharm 导包提示 unresolved reference完整解决方案

    描述 xff1a 模块部分 xff0c 写一个外部模块导入的时候居然提示unresolved reference xff0c 下面是解决方案 PyCharm 导包提示 unresolved reference解决方法是把文件夹设置为根目录
  • vue3 + vite + ts + setup , 第二十练 vue3 中使用unocss原子化

    什么是css原子化 xff1f CSS原子化的优缺点 1 减少了css体积 xff0c 提高了css复用 2 减少起名的复杂度 3 增加了记忆成本 将css拆分为原子之后 xff0c 你势必要记住一些class才能书写 xff0c 哪怕ta
  • 关于spacy和en_core_web_sm的一些问题解决办法

    报错 OSError E053 Could not read config cfg from C Users pc AppData Local Programs Python Python38 Lib site packages en co
  • Error running ‘xxApplication‘: Command line is too long. Shorten command line for ......

    idea 项目无法启动解决报错 xff1a Error running xxApplication Command line is too long Shorten command line for SvrCloudCareApplicat
  • linux发布项目以及常用操作

    linux的常用操作 xff0c 基于Xshell和Xftp 先把下载地址给兄弟们安排上 xff1a https www netsarang com zh free for home school Xshell xff1a Xshell 是
  • java接收回调通知实现方式

    演示POST方式发送通知信息 xff0c 请求参数位于request中的body中 记录一次回调参数的对接 xff0c 写起来感觉很简单 xff0c 但是表达就感觉特别难 文章内容仅供参考 xff0c 内容有误请及时指出纠正 回调通知示例
  • 低纬度与地址互换,根据经纬度计算距离

    1 根据地址 xff0c 返回对应的经纬度 2 根据输入的经纬度 xff0c 返回对应的地址 3 根据两个位置的经纬度 xff0c 来计算两地的距离 直接上代码 span class token keyword package span s
  • java实现导入Excel数据入库

    java实现导入Excel数据入库 引入依赖 span class token tag span class token tag span class token punctuation lt span dependency span sp