springboot 加layui导入excell表格数据并插入数据库

先在后台获取表格数据
前端layui上传代码

   <div class="layui-input-block">
                <button type="button" class="layui-btn" id="test1">
                    <i class="layui-icon">&#xe67c;</i>上传表格
                </button>        
 </div>
   <script>
   layui.use(['form','laydate','upload'], function(){
    var form = layui.form;
            var laydate = layui.laydate;
            var upload = layui.upload;
            var $ = layui.$;
 //上传组件
            var uploadInst = upload.render({
                elem: '#test1' //绑定元素
                ,url: '/index/uploadFile' //上传接口
                ,accept: 'xls' //允许上传的文件类型
                //,acceptMime:'xls'
                ,exts:'xls'
                ,done: function(res){
                    //上传完毕回调
                    if(res.code==0)
                    {
                        layer.msg("上传成功");

                    }else
                    {
                        layer.alert(res.msg);
                    }
                }
                ,error: function(){
                    //请求异常回调
                }
            });

}
   </script>

后台控制器Bj_Controller

 /**
     * 文件上传
     */
    @RequestMapping("/index/uploadFile")
    public @ResponseBody
    Map uploadImage(@RequestParam("file") MultipartFile file) throws IOException, ParseException {

        Map<String,Object> result=new HashMap<>();
        List<Zbqk> infoList=new ArrayList<>();
        Boolean n,flag=null;
        //判断文件版本
        String fileName = file.getOriginalFilename();
        String suffix = fileName.substring(fileName.lastIndexOf(".")+1);

        InputStream ins = file.getInputStream();
        Workbook wb = null;
        if(suffix.equals("xlsx")){
            wb = new XSSFWorkbook(ins);
        }else{
            wb = new HSSFWorkbook(ins);
        }
        //获取excel表单
        Sheet sheet = wb.getSheetAt(0);

        //line = 1:从表的第二行开始获取记录
        if(null != sheet){
            for(int line = 1; line <= sheet.getLastRowNum();line++){
//                Zbqk sendmessage = new Zbqk();
                Row row = sheet.getRow(line);
                if(null == row){
                    continue;
                }
                //将从Excel表中读取的内容转成String格式(如果Excel表格中纯数字,不执行一下操作,会报错,建议一下操作全部执行。)
              //  row.getCell(0).setCellValue(String.valueOf(CellType.STRING));
         //    日期格式不用执行
                row.getCell(1).setCellType(CellType.STRING);
                row.getCell(2).setCellType(CellType.STRING);
                row.getCell(3).setCellType(CellType.STRING);
                row.getCell(4).setCellType(CellType.STRING);
                row.getCell(5).setCellType(CellType.STRING);
                row.getCell(6).setCellType(CellType.STRING);
                row.getCell(7).setCellType(CellType.STRING);
                row.getCell(8).setCellType(CellType.STRING);

                //获取第一个单元格的内容
                Date zb_bj_time = row.getCell(0).getDateCellValue();
                SimpleDateFormat zb_bj_time2 = new SimpleDateFormat("EEE MMM dd HH:mm:ss zzz yyyy", Locale.US);
                Date d = zb_bj_time2.parse(zb_bj_time.toString());
                zb_bj_time2=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
                String bj_time=zb_bj_time2.format(d);
               // System.out.println(bj_time);

                //获取第二个单元格的内容
                String bj_sbyx = row.getCell(1).getStringCellValue();
                String bj_ptbj = row.getCell(2).getStringCellValue();
                String bj_jkyq = row.getCell(3).getStringCellValue();
                String bj_ptyx = row.getCell(4).getStringCellValue();
                String desc = row.getCell(5).getStringCellValue();
                String bj_lfry = row.getCell(6).getStringCellValue();
                String bj_name = row.getCell(7).getStringCellValue();
                String bj_beizhu = row.getCell(8).getStringCellValue();
                //Date类型
//                String insert_date = row.getCell(5).getStringCellValue();
//                Date date = null;
//                DateFormat format = new SimpleDateFormat("yyyy-MM-dd");
//                date = format.parse(insert_date);
//
//                //Integer类型
//                Integer i = null;
//                String status = row.getCell(6).getStringCellValue();
//                if(status.equals("") || status.equals(null)) {
//                    i = null;
//                }else {
//                    i = Integer.parseInt(status);
//                }
//
//                String msg_group = row.getCell(7).getStringCellValue();
//                String report_status = row.getCell(8).getStringCellValue();
//                String error_code = row.getCell(9).getStringCellValue();
//
//                String receive_date = row.getCell(10).getStringCellValue();
//                Date date2 = null;
//                DateFormat format2 = new SimpleDateFormat("yyyy-MM-dd");
//                date2 = format2.parse(receive_date);
//
//                String send_date = row.getCell(11).getStringCellValue();
//                Date date3 = null;
//                DateFormat format3 = new SimpleDateFormat("yyyy-MM-dd");
//                date3 = format3.parse(receive_date);

                Zbqk zbqk=new Zbqk(bj_time,bj_sbyx,bj_ptyx,bj_ptbj,bj_jkyq,desc,bj_lfry,bj_name,bj_beizhu);
                infoList.add(zbqk);
        //插入数据库操作        n=bjMapper.info_add(bj_time,bj_sbyx,bj_ptyx,bj_ptbj,bj_jkyq,desc,bj_lfry,bj_name,bj_beizhu);
                if(n){
                    flag=true;
                }else{
                    flag=false;
                }
            }
//            for(Zbqk zbqk:infoList){
//
//            }
            System.out.println(infoList);
        }else{
            result.put("msg", "文件错误");
            result.put("code", "1");
            return result;
        }
        if(flag) {
            result.put("msg", "ok");
            result.put("code", "0");
            return result;
        }else{
            result.put("msg", "文件错误");
            result.put("code", "1");
            return result;
        }

    }

表格格式
在这里插入图片描述
注意:需要严格按照excell表格格式输入数据(不能空或者输入数字)
如果需要数字的话可以看被屏蔽的代码

需要注意的是表格第一行为时间戳
Fri Jun 26 00:00:00 CST 2020这种格式
我们需要转化为yyyy-MM-dd格式
否则会报错java.text.ParseException: Unparseable date:“Fri Jun 26 00:00:00 CST 2020”
转化代码

//获取第一个单元格的内容
                Date zb_bj_time = row.getCell(0).getDateCellValue();
                SimpleDateFormat zb_bj_time2 = new SimpleDateFormat("EEE MMM dd HH:mm:ss zzz yyyy", Locale.US);
                Date d = zb_bj_time2.parse(zb_bj_time.toString());
                zb_bj_time2=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
                String bj_time=zb_bj_time2.format(d);
               // System.out.println(bj_time);

成功获取到表格数据
在这里插入图片描述
插入数据库操作略(可以直接用mapper的@Insert注解插入)

  • 0
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

事情判断忘记

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值