先在后台获取表格数据
前端layui上传代码
<div class="layui-input-block">
<button type="button" class="layui-btn" id="test1">
<i class="layui-icon"></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注解插入)