导入excel
2020-05-10 本文已影响0人
ShrJanLan
1.文件上传(这里使用了layui前端框架,上传接口返回参数必须为json)
layui.use(['layer', 'upload'], function(){
var upload = layui.upload;
var layer = layui.layer;
//执行实例
//导入店铺
upload.render({
elem: '#importStores' //绑定元素
,url: '${pageContext.request.contextPath}/stores/bulkImport' //上传接口
,done: function(res){
//上传完毕回调
layer.msg(res.msg);
}
,accept: 'file'
//上传文件需为xls或xlsx
,acceptMime: 'application/vnd.ms-excel, application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'
,error: function(){
//请求异常回调
layer.msg("导入失败!");
}
});
});
2.StatusCode
/**
* 统一的状态码定义
*/
public enum StatusCode {
Success(0,"成功"),
Fail(-1,"失败"),
InvalidParams(201,"非法的参数!"),
ImportSuccess(1001,"导入成功"),
ImportFail(-1001,"导入失败");
// UserNamePasswordNotBlank(50000,"账户密码不能为空!"),
// AccessTokenNotBlank(50001,"accessToken必填,请在请求头header中塞入该字段"),
//
// TokenValidateExpireToken(60001,"Token已过期"),
// TokenValidateCheckFail(60002,"Token验证失败"),
//
// AccessTokenNotExist(70001,"Token不存在-请重新登录!"),
// AccessTokenInvalidate(70002,"无效的Token!"),
//
// AccessTokenNotExistRedis(80001,"Token不存在或已经过期-请重新登录!"),
//
// AccessSessionNotExist(90001,"用户没登录或登录Session已经过期-请重新登录!"),
//
// LoginFail(100000,"登录失败!"),
// CurrUserHasNotPermission(100001,"当前用户没有权限访问该资源或者操作!"),
// CurrUserNotLogin(100002,"当前用户没有登录,请先进行登录!");
private Integer code;
private String msg;
StatusCode(Integer code, String msg) {
this.code = code;
this.msg = msg;
}
public Integer getCode() {
return code;
}
public void setCode(Integer code) {
this.code = code;
}
public String getMsg() {
return msg;
}
public void setMsg(String msg) {
this.msg = msg;
}
}
3.BaseResponse
import com.lst.api.enums.StatusCode;
/**
* 统一的响应数据模型
*/
public class BaseResponse<T> {
private Integer code;
private String msg;
private T data;
public BaseResponse(StatusCode statusCode, T data) {
this.code = statusCode.getCode();
this.msg = statusCode.getMsg();
this.data = data;
}
public BaseResponse(Integer code, String msg, T data) {
this.code = code;
this.msg = msg;
this.data = data;
}
public BaseResponse(StatusCode statusCode) {
this.code = statusCode.getCode();
this.msg = statusCode.getMsg();
}
public BaseResponse(Integer code, String msg) {
this.code = code;
this.msg = msg;
}
public Integer getCode() {
return code;
}
public void setCode(Integer code) {
this.code = code;
}
public String getMsg() {
return msg;
}
public void setMsg(String msg) {
this.msg = msg;
}
public T getData() {
return data;
}
public void setData(T data) {
this.data = data;
}
}
4.工具类
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.formula.functions.T;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import org.springframework.web.multipart.MultipartFile;
import java.io.IOException;
import java.util.*;
/**
* 读取excel信息工具类
*/
public class ReadExcelUtil {
//总行数
private int totalRows = 0;
//总条数
private int totalCells = 0;
public int getTotalRows() {
return totalRows;
}
public int getTotalCells() {
return totalCells;
}
/**
* 读取excel信息
* @param file
* @return
*/
public Sheet readExcel(MultipartFile file) throws Exception{
// 1)HSSFWorkbook,针对office 97-2003,也就是以.xls扩展名结尾的excel文件
// 2)XSSFWorkbook,针对offic2007及以上的,也就是以.xlsx扩展名结尾的excel文件
//判断文件是否为空
if(file==null) return null;
//获取文件名
String name=file.getOriginalFilename();
//进一步判断文件是否为空(即判断其大小是否为0或其名称是否为null)
long size=file.getSize();
if(name==null || ("").equals(name) && size==0) return null;
//获取文件后缀名
String suffix = name.substring(name.lastIndexOf(".")+1);
Sheet sheet = null;
try {
if("xls".equals(suffix)){
sheet = readHw(file);
}else if("xlsx".equals(suffix)){
sheet = readXw(file);
}else{
return null;
}
} catch (Exception e) {
e.printStackTrace();
}
return sheet;
}
/**
* office 97-2003
* @param file
* @return
* @throws Exception
*/
private Sheet readHw(MultipartFile file) throws Exception{
HSSFWorkbook hw = null;
HSSFSheet sheet = null;
try {
hw = new HSSFWorkbook(file.getInputStream());
//得到第一个shell
sheet = hw.getSheetAt(0);
//得到Excel的行数
this.totalRows = sheet.getPhysicalNumberOfRows();
//得到Excel的列数(前提是有行数)
if(this.totalRows>=1 && sheet.getRow(0) != null){
this.totalCells = sheet.getRow(0).getPhysicalNumberOfCells();
}
} catch (IOException e) {
e.printStackTrace();
}finally {
//关闭资源
try {
hw.close();
} catch (IOException e) {
e.printStackTrace();
}
}
return sheet;
}
/**
* offic2007及以上
* @param file
* @return
* @throws Exception
*/
private Sheet readXw(MultipartFile file) throws Exception{
XSSFWorkbook xw = null;
XSSFSheet sheet = null;
try {
xw = new XSSFWorkbook(file.getInputStream());
//得到第一个shell
sheet = xw.getSheetAt(0);
//得到Excel的行数
this.totalRows = sheet.getPhysicalNumberOfRows();
//得到Excel的列数(前提是有行数)
if(this.totalRows>=1 && sheet.getRow(0) != null){
this.totalCells = sheet.getRow(0).getPhysicalNumberOfCells();
}
} catch (IOException e) {
e.printStackTrace();
}finally {
//关闭资源
try {
xw.close();
} catch (IOException e) {
e.printStackTrace();
}
}
return sheet;
}
}
5.遍历excel
@Transactional
@Override
public void bulkImport(MultipartFile file) throws Exception {
ReadExcelUtil reu = new ReadExcelUtil();
Sheet sheet = reu.readExcel(file);
if(sheet==null){
throw new RuntimeException("读取工作表失败!");
}
//当前时间
Date current = DateUtil.getCurrentDate();
List<String> column = new ArrayList<>();//存储列名
List<Stores> list = new ArrayList<>();
for (int r = 0;r<reu.getTotalRows();r++) {
Row row = sheet.getRow(r);
if (row == null) continue;
//循环Excel的列
Stores stores = new Stores();
for(int c = 0; c <reu.getTotalCells(); c++){
Cell cell = row.getCell(c);
cell.setCellType(Cell.CELL_TYPE_STRING);//设置Cell的类型
String value = cell.getStringCellValue();
//去除回车或换行
value = value.replaceAll("\r|\n", "");
if(r==0){//获取列名
column.add(value);
}else{
if("店铺名称".equals(column.get(c))){
stores.setName(value);
}
}
}
if(r!=0){
stores.setCreateTime(current);
stores.setUpdateTime(current);
stores.setIsDelete(false);//默认有效
list.add(stores);
}
}
if(list.size()>99){//SqlServer 对语句的条数和参数的数量都有限制,分别是 1000 和 2100。
List<Stores> lists = new ArrayList<>();
for (int i=0;i<list.size();i++){
lists.add(list.get(i));
if(i!=0 && i%99==0 || i==list.size()-1){//每100条批量导入
//批量导入
storesMapper.bulkImport(lists);
lists = new ArrayList<>();
}
}
}else{
//批量导入
storesMapper.bulkImport(list);
}
}