java将Excel文件上传并解析为List数组
2024-10-17 00:25:24
前端
//导入excel文件
layui.use('upload', function() {
var upload =layui.upload; //指定允许上传的文件类型
var uploadInst = upload.render({
elem: '#btn_import'
,url: contextPath + "/service/eoms/ordermgt/importExcel.ilf"
,accept: 'file' //普通文件
,done: function(res){
console.log(res);
alert("success");
}
});
});
java controller
//导入excel表格并解析
@RequestMapping(value = "/importExcel.ilf")
@ResponseBody
public JSONObject importExcel(HttpServletRequest request,HttpServletResponse response,MultipartFile file) throws IOException {
String originalFilename = file.getOriginalFilename();
String type = file.getContentType();
//originalFilename = UUID.randomUUID().toString()+originalFilename;
System.out.println("目标文件名称:"+originalFilename+",目标文件类型:"+type); InputStream is = file.getInputStream();
//Workbook createWorkbook = importExcel.createWorkbook(is, type); //
ImportExcel importExcel = new ImportExcel();
List<Object> list= importExcel.importDataFromExcel( is, originalFilename);
for(int i = 0;i<list.size();i++){
System.out.println(list.get(i).toString());
} JSONObject json=new JSONObject(); return json;
}
/**
* @ClassName: ExcelUtil
* @Description: Excel导入工具类
* @date
*/
public class ImportExcel {
private static final Logger logger = Logger.getLogger(ImportExcel.class); /**
* @Title: createWorkbook
* @Description: 判断excel文件后缀名,生成不同的workbook * @param @param is
* @param @param excelFileName
* @param @return
* @param @throws IOException
* @return Workbook
* @throws
*/
public Workbook createWorkbook(InputStream is,String excelFileName) throws IOException{
if (excelFileName.endsWith(".xls")) {
return new HSSFWorkbook(is);
}else if (excelFileName.endsWith(".xlsx")) {
return new XSSFWorkbook(is);
}
return null;
} /**
* @Title: getSheet
* @Description: 根据sheet索引号获取对应的sheet
* @param @param workbook
* @param @param sheetIndex
* @param @return
* @return Sheet
* @throws
*/
public Sheet getSheet(Workbook workbook,int sheetIndex){
return workbook.getSheetAt(0);
} public List<Object> importDataFromExcel(InputStream is,String excelFileName){
List<Object> list = new ArrayList<Object>();
try {
//创建工作簿
Workbook workbook = this.createWorkbook(is, excelFileName);
//创建工作表sheet
Sheet sheet = this.getSheet(workbook, 0);
//获取sheet中数据的行数
int rows = sheet.getPhysicalNumberOfRows();
//获取表头单元格个数
int cells = sheet.getRow(0).getPhysicalNumberOfCells(); for (int i = 1; i < rows; i++) {//第一行为标题栏,从第二行开始取数据 //利用反射,给JavaBean的属性进行赋值
ImportExcelFile vo = new ImportExcelFile();
Field[] fields = vo.getClass().getDeclaredFields(); Row row = sheet.getRow(i);
int index = 0;
while (index < cells) {
Cell cell = row.getCell(index);
if (null == cell) {
cell = row.createCell(index);
}
cell.setCellType(Cell.CELL_TYPE_STRING);
String value = null == cell.getStringCellValue()?"":cell.getStringCellValue(); Field field = fields[index];
String fieldName = field.getName();
String methodName = "set"+fieldName.substring(0,1).toUpperCase()+fieldName.substring(1);
Method setMethod = vo.getClass().getMethod(methodName, new Class[]{String.class});
setMethod.invoke(vo, new Object[]{value});
index++;
}
if (isHasValues(vo)) {//判断对象属性是否有值
list.add(vo);
//vo.getClass().getConstructor(new Class[]{}).newInstance(new Object[]{});//重新创建一个vo对象
} }
} catch (Exception e) {
logger.error(e);
}finally{
try {
is.close();//关闭流
} catch (Exception e2) {
logger.error(e2);
}
}
return list; } /**
* @Title: isHasValues
* @Description: 判断一个对象所有属性是否有值,如果一个属性有值(分空),则返回true
* @param @param object
* @param @return
* @return boolean
* @throws
*/
public boolean isHasValues(Object object){
Field[] fields = object.getClass().getDeclaredFields();
boolean flag = false;
for (int i = 0; i < fields.length; i++) {
String fieldName = fields[i].getName();
String methodName = "get"+fieldName.substring(0, 1).toUpperCase()+fieldName.substring(1);
Method getMethod;
try {
getMethod = object.getClass().getMethod(methodName);
Object obj = getMethod.invoke(object);
if (null != obj && !"".equals(obj)) {
flag = true;
break;
}
} catch (Exception e) {
logger.error(e);
}
}
return flag; }
dao层
package com.inspur.om.order.data; public class ImportExcelFile {
private String orderId;
private String orderName;
private String orderType;
public String getOrderId() {
return orderId;
}
public void setOrderId(String orderId) {
this.orderId = orderId;
}
public String getOrderName() {
return orderName;
}
public void setOrderName(String orderName) {
this.orderName = orderName;
}
public String getOrderType() {
return orderType;
}
public void setOrderType(String orderType) {
this.orderType = orderType;
}
@Override
public String toString() {
return "ImportExcelFile [orderId=" + orderId + ", orderName="
+ orderName + ", orderType=" + orderType + "]";
} }
最新文章
- 0042 MySQL学习笔记-入门--01
- MFC覆盖OnPrepareDC实现“所见即所得”打印
- JavaScript使用DeviceOne开发实战(一) 配置和起步
- Java递归算法——阶乘
- Sightseeing(poj 3463)
- OS开发网络篇—监测网络状态
- HDU 3586 : Information Disturbing
- CentOS 下PHP的卸载
- asp.net core2.0网站的环境搭建和网站部署
- 深度学习系列 Part (2)
- tableView//collectionView加载时的动画
- springboot整合springdata-jpa
- Docker系列10—容器编排工具Docker Compose详解
- Jarvis OJ 一些简单的re刷题记录和脚本
- 调试JS代码的神器
- Python之聚类(KMeans,KMeans++)
- DataTables合并单元格(rowspan)的实现思路(多分组分类的情况)
- Redis复制与可扩展集群搭建【转】
- 愿Linux红帽旋风吹得更加猛烈吧!
- Sencha Cmd 5.0.1.231 是坑爹货