From 3eba8b62a62ecb56f8d286d5a93ba2768d54e3f3 Mon Sep 17 00:00:00 2001
From: cuilei <ray_tsu1@163.com>
Date: 星期四, 15 五月 2025 17:55:22 +0800
Subject: [PATCH] 工具管理-工具分类特征参数:刀片参数、通用工具参数导入

---
 lxzn-module-tms/src/main/java/org/jeecg/modules/tms/controller/ParaBladeController.java |  252 +++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 249 insertions(+), 3 deletions(-)

diff --git a/lxzn-module-tms/src/main/java/org/jeecg/modules/tms/controller/ParaBladeController.java b/lxzn-module-tms/src/main/java/org/jeecg/modules/tms/controller/ParaBladeController.java
index 701758f..686f12c 100644
--- a/lxzn-module-tms/src/main/java/org/jeecg/modules/tms/controller/ParaBladeController.java
+++ b/lxzn-module-tms/src/main/java/org/jeecg/modules/tms/controller/ParaBladeController.java
@@ -1,5 +1,8 @@
 package org.jeecg.modules.tms.controller;
 
+import java.io.File;
+import java.io.InputStream;
+import java.util.ArrayList;
 import java.util.Arrays;
 import java.util.List;
 import java.util.Map;
@@ -9,17 +12,27 @@
 import java.net.URLDecoder;
 import javax.servlet.http.HttpServletRequest;
 import javax.servlet.http.HttpServletResponse;
+import cn.hutool.core.collection.CollectionUtil;
+import com.alibaba.fastjson.JSONObject;
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import org.apache.poi.ss.usermodel.*;
+import org.apache.poi.xssf.usermodel.XSSFWorkbook;
 import org.jeecg.common.api.vo.Result;
+import org.jeecg.common.constant.CommonConstant;
 import org.jeecg.common.system.query.QueryGenerator;
+import org.jeecg.common.util.PmsUtil;
 import org.jeecg.common.util.oConvertUtils;
+import org.jeecg.modules.tms.entity.BaseTools;
 import org.jeecg.modules.tms.entity.ParaBlade;
+import org.jeecg.modules.tms.entity.ToolsClassify;
+import org.jeecg.modules.tms.service.IBaseToolsService;
 import org.jeecg.modules.tms.service.IParaBladeService;
-
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import lombok.extern.slf4j.Slf4j;
-
+import org.jeecg.modules.tms.service.IToolsClassifyService;
+import org.jeecg.modules.tms.utils.ExcelUtils;
 import org.jeecgframework.poi.excel.ExcelImportUtil;
 import org.jeecgframework.poi.excel.def.NormalExcelConstants;
 import org.jeecgframework.poi.excel.entity.ExportParams;
@@ -49,6 +62,10 @@
 public class ParaBladeController extends JeecgController<ParaBlade, IParaBladeService> {
 	@Autowired
 	private IParaBladeService paraBladeService;
+	@Autowired
+	private IToolsClassifyService toolsClassifyService;
+	@Autowired
+	private IBaseToolsService baseToolsService;
 	
 	/**
 	 * 鍒嗛〉鍒楄〃鏌ヨ
@@ -171,7 +188,236 @@
     //@RequiresPermissions("tms_para_blade:importExcel")
     @RequestMapping(value = "/importExcel", method = RequestMethod.POST)
     public Result<?> importExcel(HttpServletRequest request, HttpServletResponse response) {
-        return super.importExcel(request, response, ParaBlade.class);
+		MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request;
+		Map<String, MultipartFile> fileMap = multipartRequest.getFileMap();
+		// 閿欒淇℃伅
+		List<String> errorMessage = new ArrayList<>();
+		int successLines = 0, errorLines = 0, dataLines = 0;
+		List<ParaBlade> paraBladeImportList = new ArrayList<>();
+		try {
+			for (Map.Entry<String, MultipartFile> entity : fileMap.entrySet()) {
+				// 鑾峰彇涓婁紶鏂囦欢瀵硅薄
+				MultipartFile file = entity.getValue();
+				InputStream inputStream = file.getInputStream();
+				Workbook workbook = new XSSFWorkbook(inputStream);
+				Sheet sheet = workbook.getSheetAt(0);
+				for (Row row : sheet) {
+					ParaBlade paraBlade = new ParaBlade();
+					int rowNum = row.getRowNum();
+					int currentRowNum  = rowNum + 1;
+					//琛ㄥご琛屽拰绌鸿鐣ヨ繃
+					if (rowNum == 0 || ExcelUtils.isRowEmpty(row)) {
+						continue;
+					}
+					dataLines++;
+					Cell cell1 = row.getCell(1);
+					if (cell1 == null || cell1.getCellType() == CellType.BLANK) {
+						errorMessage.add("绗�" + currentRowNum + "琛岋紝鏁版嵁瀵煎叆澶辫触,涓�绾у垎绫诲悕绉颁负绌�! ");
+						errorLines++;
+						continue;
+					}
+					Cell cell2 = row.getCell(2);
+					if (cell2 == null || cell2.getCellType() == CellType.BLANK) {
+						errorMessage.add("绗�" + currentRowNum + "琛岋紝鏁版嵁瀵煎叆澶辫触,浜岀骇鍒嗙被鍚嶇О涓虹┖! ");
+						errorLines++;
+						continue;
+					}
+					Cell cell3 = row.getCell(3);
+					if (cell3 == null || cell3.getCellType() == CellType.BLANK) {
+						errorMessage.add("绗�" + currentRowNum + "琛岋紝鏁版嵁瀵煎叆澶辫触,涓夌骇鍒嗙被鍚嶇О涓虹┖! ");
+						errorLines++;
+						continue;
+					}
+					Cell cell4 = row.getCell(4);
+					if (cell4 == null || cell4.getCellType() == CellType.BLANK) {
+						errorMessage.add("绗�" + currentRowNum + "琛岋紝鏁版嵁瀵煎叆澶辫触,鍥涚骇鍒嗙被鍚嶇О涓虹┖! ");
+						errorLines++;
+						continue;
+					}
+					Cell cell9 = row.getCell(9);
+					if (cell9 == null || cell9.getCellType() == CellType.BLANK) {
+						errorMessage.add("绗�" + currentRowNum + "琛岋紝鏁版嵁瀵煎叆澶辫触,鍨嬪彿/鍥惧彿涓虹┖! ");
+						errorLines++;
+						continue;
+					}
+					//鏍规嵁鍥涚骇鍒嗙被鍚嶇О鍜屽瀷鍙�/鍥惧彿鏌ヨ宸ュ叿淇℃伅
+					List<ToolsClassify> toolClassifyList = toolsClassifyService.list(new LambdaQueryWrapper<ToolsClassify>()
+							.eq(ToolsClassify::getTypeName, ExcelUtils.getCellValueAsString(cell4))
+							.eq(ToolsClassify::getStatus, CommonConstant.STATUS_1));
+					if (CollectionUtil.isEmpty(toolClassifyList)) {
+						errorMessage.add("绗�" + currentRowNum + "琛岋紝鏁版嵁瀵煎叆澶辫触,绯荤粺涓嶅瓨鍦ㄨ鍥涚骇鍒嗙被鍚嶇О! ");
+						errorLines++;
+						continue;
+					} else {
+						ToolsClassify toolsClassify = toolClassifyList.get(0);
+						List<BaseTools> baseToolsList = baseToolsService.list(new LambdaQueryWrapper<BaseTools>()
+								.eq(BaseTools::getClassifyId, toolsClassify.getId())
+								.eq(BaseTools::getToolModel, ExcelUtils.getCellValueAsString(cell9)));
+						if (CollectionUtil.isEmpty(baseToolsList)) {
+							errorMessage.add("绗�" + currentRowNum + "琛岋紝鏁版嵁瀵煎叆澶辫触,绯荤粺涓嶅瓨鍦ㄥ搴旂殑宸ュ叿淇℃伅! ");
+							errorLines++;
+							continue;
+						} else {
+							BaseTools baseTools = baseToolsList.get(0);
+							List<ParaBlade> paraThreadingToolList = paraBladeService.list(new LambdaQueryWrapper<ParaBlade>()
+									.eq(ParaBlade::getToolCode, baseTools.getId())
+									.eq(ParaBlade::getToolModel, ExcelUtils.getCellValueAsString(cell9)));
+							if (CollectionUtil.isEmpty(paraThreadingToolList)) {
+								paraBlade.setClassifyId(toolsClassify.getId());
+								paraBlade.setToolCode(baseTools.getId());
+								paraBlade.setToolModel(ExcelUtils.getCellValueAsString(cell9));
+							} else {
+								paraBlade = paraThreadingToolList.get(0);
+							}
+						}
+					}
+
+					Cell cell0 = row.getCell(0);//搴忓彿(鎴栦紒涓氬唴鍘熶唬鐮�)
+					paraBlade.setSignCode(ExcelUtils.getCellValueAsString(cell0));
+					Cell cell5 = row.getCell(5);//鐗╁搧涓枃鍚嶇О
+					if (cell5 == null || cell5.getCellType() == CellType.BLANK) {
+						errorMessage.add("绗�" + currentRowNum + "琛岋紝鏁版嵁瀵煎叆澶辫触,鐗╁搧涓枃鍚嶇О涓虹┖! ");
+						errorLines++;
+						continue;
+					} else {
+						paraBlade.setChineseName(ExcelUtils.getCellValueAsString(cell5));
+					}
+					Cell cell6 = row.getCell(6);//鐗╁搧澶栨枃鍚嶇О
+					paraBlade.setForeignLanguageName(ExcelUtils.getCellValueAsString(cell6));
+					Cell cell7 = row.getCell(7);//鏍囧噯绾у埆
+					paraBlade.setStandardLevel(ExcelUtils.getCellValueAsString(cell7));
+					Cell cell8 = row.getCell(8);//鏍囧噯鍙�
+					paraBlade.setStandardCode(ExcelUtils.getCellValueAsString(cell8));
+					Cell cell10 = row.getCell(10);//鍒�鐗囧舰鐘�
+					if (cell10 == null || cell10.getCellType() == CellType.BLANK) {
+						errorMessage.add("绗�" + currentRowNum + "琛岋紝鏁版嵁瀵煎叆澶辫触,鍒�鐗囧舰鐘朵负绌�! ");
+						errorLines++;
+						continue;
+					} else {
+						paraBlade.setBladeShape(ExcelUtils.getCellValueAsString(cell10));
+					}
+					Cell cell11 = row.getCell(11);//鍒�鐗囬暱搴�
+					if (cell11 == null || cell11.getCellType() == CellType.BLANK) {
+						errorMessage.add("绗�" + currentRowNum + "琛岋紝鏁版嵁瀵煎叆澶辫触,鍒�鐗囬暱搴︿负绌�! ");
+						errorLines++;
+						continue;
+					} else {
+						paraBlade.setBladeLength(ExcelUtils.getCellValueAsString(cell11));
+					}
+
+					Cell cell12 = row.getCell(12);//鍒囧墛鍒冩暟
+					if (cell12 == null || cell12.getCellType() == CellType.BLANK) {
+						errorMessage.add("绗�" + currentRowNum + "琛岋紝鏁版嵁瀵煎叆澶辫触,鍒囧墛鍒冩暟涓虹┖! ");
+						errorLines++;
+						continue;
+					} else {
+						paraBlade.setCuttingEdgeCount(ExcelUtils.getCellValueAsString(cell12));
+					}
+					Cell cell13 = row.getCell(13);//鍒�鐗囧帤搴�
+					if (cell13 == null || cell13.getCellType() == CellType.BLANK) {
+						errorMessage.add("绗�" + currentRowNum + "琛岋紝鏁版嵁瀵煎叆澶辫触,鍒�鐗囧帤搴︿负绌�! ");
+						errorLines++;
+						continue;
+					} else {
+						paraBlade.setBladeThickness(ExcelUtils.getCellValueAsString(cell13));
+					}
+					Cell cell14 = row.getCell(14);//澶瑰浐褰㈠紡
+					if (cell14 == null || cell14.getCellType() == CellType.BLANK) {
+						errorMessage.add("绗�" + currentRowNum + "琛岋紝鏁版嵁瀵煎叆澶辫触,澶瑰浐褰㈠紡涓虹┖! ");
+						errorLines++;
+						continue;
+					} else {
+						paraBlade.setClampingType(ExcelUtils.getCellValueAsString(cell14));
+					}
+					Cell cell15 = row.getCell(15);//鍒�灏朢
+					if (cell15 == null || cell15.getCellType() == CellType.BLANK) {
+						errorMessage.add("绗�" + currentRowNum + "琛岋紝鏁版嵁瀵煎叆澶辫触,鍒�灏朢涓虹┖! ");
+						errorLines++;
+						continue;
+					} else {
+						paraBlade.setNoseAngleR(ExcelUtils.getCellValueAsString(cell15));
+					}
+
+					Cell cell16 = row.getCell(16);//鍒�鐗囨潗鏂�
+					if (cell16 == null || cell16.getCellType() == CellType.BLANK) {
+						errorMessage.add("绗�" + currentRowNum + "琛岋紝鏁版嵁瀵煎叆澶辫触,鍒�鐗囨潗鏂欎负绌�! ");
+						errorLines++;
+						continue;
+					} else {
+						paraBlade.setToolMaterial(ExcelUtils.getCellValueAsString(cell16));
+					}
+					Cell cell17 = row.getCell(17);//闆朵欢鏉愭枡
+					paraBlade.setPartMaterial(ExcelUtils.getCellValueAsString(cell17));
+					Cell cell18 = row.getCell(18);//鏄惁娑傚眰
+					if (cell18 == null || cell18.getCellType() == CellType.BLANK) {
+						errorMessage.add("绗�" + currentRowNum + "琛岋紝鏁版嵁瀵煎叆澶辫触,鏄惁娑傚眰涓虹┖! ");
+						errorLines++;
+						continue;
+					} else {
+						paraBlade.setPaintcoatFlag(ExcelUtils.getCellValueAsString(cell18));
+					}
+					Cell cell19 = row.getCell(19);//闄勫姞鎶�鏈潯浠�
+					if (cell19 == null || cell19.getCellType() == CellType.BLANK) {
+						errorMessage.add("绗�" + currentRowNum + "琛岋紝鏁版嵁瀵煎叆澶辫触,闄勫姞鎶�鏈潯浠朵负绌猴紒");
+						errorLines++;
+						continue;
+					} else {
+						paraBlade.setTechnicalConditions(ExcelUtils.getCellValueAsString(cell19));
+					}
+					Cell cell20 = row.getCell(20);//闄勫姞鎶�鏈潯浠惰鏄�
+					paraBlade.setConditionsInfo(ExcelUtils.getCellValueAsString(cell20));
+					Cell cell21 = row.getCell(21);//鍝佺墝
+					paraBlade.setBrand(ExcelUtils.getCellValueAsString(cell21));
+					Cell cell22 = row.getCell(22);//鍒跺紡
+					paraBlade.setTypes(ExcelUtils.getCellValueAsString(cell22));
+					Cell cell23 = row.getCell(23);//娑傚眰鏉愭枡
+					paraBlade.setCoatingMaterial(ExcelUtils.getCellValueAsString(cell23));
+					Cell cell24 = row.getCell(24);//鍔犲伐鍒嗙被
+					paraBlade.setProcessingClassify(ExcelUtils.getCellValueAsString(cell24));
+					Cell cell25 = row.getCell(25);//鍒�鐗囧悗瑙�
+					paraBlade.setBladePosterior(ExcelUtils.getCellValueAsString(cell25));
+					Cell cell26 = row.getCell(26);//鍒囧墛鏂瑰悜
+					paraBlade.setCuttingDirection(ExcelUtils.getCellValueAsString(cell26));
+					Cell cell27 = row.getCell(27);//鍒�鐗囧搴�
+					paraBlade.setBladeWide(ExcelUtils.getCellValueAsString(cell27));
+					Cell cell28 = row.getCell(28);//鍒�鐗囧昂瀵�
+					paraBlade.setBladeSize(ExcelUtils.getCellValueAsString(cell28));
+					Cell cell29 = row.getCell(29);//鍐呭铻虹汗
+					paraBlade.setInOutThread(ExcelUtils.getCellValueAsString(cell29));
+					Cell cell30 = row.getCell(30);//铻虹汗鏍囧噯
+					paraBlade.setThreadStandard(ExcelUtils.getCellValueAsString(cell30));
+					Cell cell31 = row.getCell(31);//鐗欏瀷瑙掑害
+					paraBlade.setDentalAngle(ExcelUtils.getCellValueAsString(cell31));
+					Cell cell32 = row.getCell(32);//铻鸿窛
+					paraBlade.setPitch(ExcelUtils.getCellValueAsString(cell32));
+					Cell cell33 = row.getCell(33);//鏈�灏忓姞宸ュ唴铻虹汗鍏О鐩村緞
+					paraBlade.setMinInternalThread(ExcelUtils.getCellValueAsString(cell33));
+
+					paraBladeImportList.add(paraBlade);
+					successLines++;
+				}
+			}
+			paraBladeService.saveOrUpdateBatch(paraBladeImportList);
+			if (successLines == dataLines) {
+				return Result.OK("鍏�" + dataLines + "琛屾暟鎹叏閮ㄥ鍏ユ垚鍔燂紒");
+			} else {
+				JSONObject result = new JSONObject(5);
+				result.put("successCount", successLines);
+				result.put("msg", "鎬讳笂浼犺鏁帮細" + dataLines + "锛屾垚鍔熷鍏ヨ鏁帮細" + successLines);
+				result.put("errorMsg", errorMessage);
+				String fileUrl = PmsUtil.saveErrorMsgByList(errorMessage, "userImportExcelErrorLog");
+				int lastIndex = fileUrl.lastIndexOf(File.separator);
+				String fileName = fileUrl.substring(lastIndex + 1);
+				result.put("fileUrl", "/sys/common/static/" + fileUrl);
+				result.put("fileName", fileName);
+				Result res = Result.ok(result);
+				res.setCode(201);
+				res.setMessage("鏂囦欢瀵煎叆鎴愬姛锛屼絾鏈夐敊璇��");
+				return res;
+			}
+		} catch (IOException e) {
+			throw new RuntimeException(e);
+		}
     }
 
 }

--
Gitblit v1.9.3