| | |
| | | package com.whyc.service; |
| | | |
| | | import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; |
| | | import com.baomidou.mybatisplus.core.toolkit.Wrappers; |
| | | import com.whyc.dto.FileUrlDTO; |
| | | import com.whyc.dto.Response; |
| | | import com.whyc.mapper.ProductBomApprovingMapper; |
| | | import com.whyc.pojo.DocUser; |
| | | import com.whyc.pojo.ProductBomApproving; |
| | | import com.whyc.pojo.WorksheetMain; |
| | | import com.whyc.util.ActionUtil; |
| | | import com.whyc.util.CommonUtil; |
| | | import com.whyc.util.Zip4jUtil; |
| | | import com.whyc.util.*; |
| | | import org.apache.poi.openxml4j.exceptions.InvalidFormatException; |
| | | import org.apache.poi.ss.usermodel.*; |
| | | import org.springframework.stereotype.Component; |
| | | import org.springframework.beans.factory.annotation.Autowired; |
| | | import org.springframework.stereotype.Service; |
| | | import org.springframework.web.multipart.MultipartFile; |
| | | |
| | | import javax.annotation.Resource; |
| | | import javax.xml.crypto.Data; |
| | | import java.io.File; |
| | | import java.io.FileOutputStream; |
| | | import java.io.IOException; |
| | | import java.io.InputStream; |
| | | import java.io.*; |
| | | import java.text.SimpleDateFormat; |
| | | import java.util.Date; |
| | | import java.util.LinkedList; |
| | | import java.util.List; |
| | | import java.util.*; |
| | | import java.util.stream.Collectors; |
| | | |
| | | @Service |
| | | public class ProductBomApprovingService { |
| | | |
| | | @Resource |
| | | private ProductBomApprovingMapper mapper; |
| | | |
| | | @Autowired |
| | | private WorksheetMainService mainService; |
| | | |
| | | public List<ProductBomApproving> excelParse(InputStream inputStream) throws IOException, InvalidFormatException { |
| | | List<ProductBomApproving> list = new LinkedList<>(); |
| | |
| | | mapper.insertBatchSomeColumn(bomList); |
| | | } |
| | | |
| | | public Response zipParse(MultipartFile file) throws IOException { |
| | | public Response zipParse(MultipartFile file) throws IOException, InvalidFormatException { |
| | | List<ProductBomApproving> list = new LinkedList<>(); |
| | | List<ProductBomApproving> bomList = new LinkedList<>(); |
| | | Response response = new Response(); |
| | | //检查是否为zip |
| | | boolean isZip = Zip4jUtil.checkZipFileParam(file); |
| | |
| | | long timeStamp = System.currentTimeMillis(); |
| | | String filePath = rootFile + File.separator + "product_approving" + File.separator + user.getName() + File.separator + dateFormat+ File.separator + timeStamp; |
| | | File parentFile = new File(filePath); |
| | | File zipFile = new File(filePath+File.separator+file.getOriginalFilename()); |
| | | if(!zipFile.exists()){ |
| | | String originalFilename = file.getOriginalFilename(); |
| | | File zipFile = new File(filePath+File.separator+ originalFilename); |
| | | /*if(!zipFile.exists()){ |
| | | zipFile.mkdirs(); |
| | | }*/ |
| | | if (!parentFile.exists()) { |
| | | parentFile.mkdirs(); |
| | | } |
| | | file.transferTo(zipFile); |
| | | //解压文件夹 |
| | | Zip4jUtil.unPackZip(zipFile,null,filePath); |
| | | //遍历解压后的文件夹路径,解析excel |
| | | System.out.println(filePath); |
| | | File[] bomFileDirArr = parentFile.listFiles(); |
| | | for (File bomFileDir : bomFileDirArr){ |
| | | String bomFileDirName = bomFileDir.getName(); |
| | | System.out.println(bomFileDirName); |
| | | File[] bomFileArr = bomFileDir.listFiles(); |
| | | for (File bomFile : bomFileArr){ |
| | | String bomFileName = bomFile.getName(); |
| | | //解析excel |
| | | if (bomFileName.contains(".xls")){ |
| | | System.out.println("待解析的excel文件为:"+bomFileName); |
| | | List<String> fileList = new ArrayList<>(); |
| | | //图纸筛选 |
| | | fileList = FileUtil.getStaticFilePath(parentFile,fileList); |
| | | List<FileUrlDTO> dwgExistsList = getDwgList(fileList); |
| | | for (int i = 0; i < fileList.size(); i++) { |
| | | String fileTempUrl = fileList.get(i); |
| | | //查询需上传的bom数据 |
| | | if(fileTempUrl.contains(".xls") && fileTempUrl.contains("(BOM)")){ |
| | | Workbook workbook = null; |
| | | InputStream inputStream = new FileInputStream(new File(fileTempUrl)); |
| | | workbook = WorkbookFactory.create(inputStream); |
| | | inputStream.close(); |
| | | List<? extends PictureData> allPictures = workbook.getAllPictures(); |
| | | //取第一个sheet表 |
| | | Sheet sheet = workbook.getSheetAt(0); |
| | | int lastRowNum = sheet.getLastRowNum(); |
| | | //取第三行,并以第三行开始 |
| | | Row row2 = sheet.getRow(1); |
| | | short lastCellNum = row2.getLastCellNum(); |
| | | for (int k = 2; k < lastRowNum+1; k++) { |
| | | ProductBomApproving bomApproving = new ProductBomApproving(); |
| | | for (int j = 0; j < lastCellNum; j++) { |
| | | Row row = sheet.getRow(k); |
| | | Cell cell = row.getCell(j); |
| | | String cellValue = null; |
| | | Double cellValueInt = 0d; |
| | | if(j == 9 ||j== 0){ |
| | | cellValueInt = cell.getNumericCellValue(); |
| | | }else if(j!=15){ |
| | | cellValue = cell.getStringCellValue(); |
| | | } |
| | | switch (j){ |
| | | case 0:{bomApproving.setId(cellValueInt.intValue());}break; |
| | | case 1:{bomApproving.setParentCode(cellValue);}break; |
| | | case 2:{bomApproving.setParentName(cellValue);}break; |
| | | case 3:{bomApproving.setParentModel(cellValue);}break; |
| | | case 4:{bomApproving.setCategory(cellValue);}break; |
| | | case 5:{bomApproving.setSubCode(cellValue); }break; |
| | | case 6:{bomApproving.setSubName(cellValue);}break; |
| | | case 7:{ |
| | | bomApproving.setSubModel(cellValue); |
| | | //判断图纸查看是否存在 |
| | | bomApproving.setDwgExist(0); |
| | | String dwgFileName = cellValue+".dwg"; |
| | | for (int n = 0; n < dwgExistsList.size(); n++) { |
| | | FileUrlDTO fileUrlDTO = dwgExistsList.get(n); |
| | | if(dwgFileName.toUpperCase().equals(fileUrlDTO.getFileName().toUpperCase())){ |
| | | //存在 |
| | | bomApproving.setDwgExist(1); |
| | | bomApproving.setDwgUrl(fileUrlDTO.getHttpFileUrl()); |
| | | break; |
| | | } |
| | | } |
| | | }break; |
| | | case 8:{bomApproving.setUnit(cellValue);}break; |
| | | case 9:{bomApproving.setQuantity(cellValueInt.intValue());}break; |
| | | case 10:{bomApproving.setProducer(cellValue);}break; |
| | | case 11:{bomApproving.setMaterial(cellValue);}break; |
| | | case 12:{bomApproving.setThickness(cellValue);}break; |
| | | case 13:{bomApproving.setSurfaceDetail(cellValue);}break; |
| | | case 14:{bomApproving.setNotes(cellValue);}break; |
| | | case 15:{ |
| | | //图片,从0开始,到图片size为止 |
| | | int m = k-2; |
| | | if(m<allPictures.size()){ |
| | | PictureData pictureData = allPictures.get(m); |
| | | //图片存储 product_approving/username/2022-07/ |
| | | String approvingPath = rootFile + File.separator + "product_approving" + File.separator + user.getName() + File.separator + dateFormat+ File.separator + timeStamp; |
| | | File provingFile = new File(approvingPath); |
| | | if(!provingFile.exists()){ |
| | | provingFile.mkdirs(); |
| | | } |
| | | String suffix = pictureData.suggestFileExtension(); |
| | | String picturePath = approvingPath + File.separator + bomApproving.getSubModel() + "." + suffix; |
| | | String picturePathFront = "doc_file" + File.separator + "product_approving" + File.separator + user.getName() + File.separator + dateFormat + File.separator + timeStamp + File.separator + bomApproving.getSubModel() + "." + suffix; |
| | | byte[] data = pictureData.getData(); |
| | | FileOutputStream fileOutputStream = null; |
| | | File pictureFile = new File(picturePath); |
| | | fileOutputStream = new FileOutputStream(pictureFile); |
| | | fileOutputStream.write(data); |
| | | |
| | | bomApproving.setPictureUrl(picturePathFront); |
| | | } |
| | | }break; |
| | | } |
| | | } |
| | | bomList.add(bomApproving); |
| | | } |
| | | } |
| | | /*//这个是子表数据,用做对比校验 |
| | | else if(fileTempUrl.contains(".xls")){ |
| | | File fileTemp = new File(fileTempUrl); |
| | | Workbook workbook = null; |
| | | workbook = WorkbookFactory.create(fileTemp); |
| | | List<? extends PictureData> allPictures = workbook.getAllPictures(); |
| | | //取第一个sheet表 |
| | | Sheet sheet = workbook.getSheetAt(0); |
| | | int lastRowNum = sheet.getLastRowNum(); |
| | | //取第三行,并以第三行开始 |
| | | Row rowTemp = sheet.getRow(1); |
| | | short lastCellNum = rowTemp.getLastCellNum(); |
| | | //先单独获取产品型号和版本号/分类 |
| | | Row row = sheet.getRow(1); |
| | | String type = row.getCell(1).getStringCellValue(); |
| | | |
| | | Row row2 = sheet.getRow(2); |
| | | String productModel = row2.getCell(5).getStringCellValue(); |
| | | Row row3 = sheet.getRow(3); |
| | | String productVersion = row3.getCell(5).getStringCellValue(); |
| | | for (int l = 9; l < lastRowNum-1; l++) { |
| | | ProductBomApproving bomApproving = new ProductBomApproving(); |
| | | bomApproving.setParentModel(productModel); |
| | | //lxw注释 |
| | | //bomApproving.setParentVersion(productVersion); |
| | | bomApproving.setType(type); |
| | | bomApproving.setExcelName(fileTempUrl.substring(fileTempUrl.lastIndexOf(File.separator)+1)); |
| | | |
| | | for (int m = 2; m < lastCellNum; m++) { |
| | | row = sheet.getRow(l); |
| | | Cell cell = row.getCell(m); |
| | | String cellValue = null; |
| | | int cellValueInt = 0; |
| | | Double cellValueDouble = null; |
| | | if(m == 3){ |
| | | cellValueDouble = cell.getNumericCellValue(); |
| | | DecimalFormat decimalFormat = new DecimalFormat("0"); |
| | | cellValue = decimalFormat.format(cellValueDouble); |
| | | } |
| | | else if(m ==7){ |
| | | cellValueDouble = cell.getNumericCellValue(); |
| | | if(cellValueDouble.equals(0d)){ |
| | | cellValue = ""; |
| | | }else{ |
| | | cellValue = cellValueDouble.toString(); |
| | | } |
| | | } |
| | | else if(m==8){ |
| | | cellValueDouble = cell.getNumericCellValue(); |
| | | } |
| | | else { |
| | | cellValue = cell.getStringCellValue(); |
| | | } |
| | | |
| | | switch (m){ |
| | | case 2:{bomApproving.setCategory(cellValue);}break; |
| | | case 3:{bomApproving.setSubCode(cellValue);}break; |
| | | case 4:{bomApproving.setSubName(cellValue);}break; |
| | | case 5:{ |
| | | bomApproving.setSubModel(cellValue); |
| | | //判断图纸查看是否存在 |
| | | bomApproving.setDwgExist(0); |
| | | String dwgFileName = cellValue+".dwg"; |
| | | for (int n = 0; n < dwgExistsList.size(); n++) { |
| | | FileUrlDTO fileUrlDTO = dwgExistsList.get(n); |
| | | if(dwgFileName.equals(fileUrlDTO.getFileName())){ |
| | | //存在 |
| | | bomApproving.setDwgExist(1); |
| | | bomApproving.setDwgUrl(fileUrlDTO.getHttpFileUrl()); |
| | | break; |
| | | } |
| | | } |
| | | }break; |
| | | case 6:{bomApproving.setMaterial(cellValue);}break; |
| | | case 7:{bomApproving.setThickness(cellValue);}break; |
| | | case 8:{bomApproving.setQuantity(cellValueDouble.intValue());}break; |
| | | case 9:{bomApproving.setSurfaceDetail(cellValue);}break; |
| | | case 10:{bomApproving.setNotes(cellValue);}break; |
| | | case 11:{ |
| | | //图片,从0开始,到图片size为止 |
| | | int k = l-9; |
| | | if(k<allPictures.size()-1){ |
| | | PictureData pictureData = allPictures.get(k+1); |
| | | //图片存储 doc_file/product_approving/${username}/{dateFormat}/${timeStamp} |
| | | String suffix = pictureData.suggestFileExtension(); |
| | | String picturePath = filePath + File.separator + bomApproving.getSubModel() + "." + suffix; |
| | | String picturePathFront = "doc_file" + File.separator + "product_approving" + File.separator + user.getName() + File.separator + dateFormat + File.separator + timeStamp + File.separator + bomApproving.getSubModel() + "." + suffix; |
| | | byte[] data = pictureData.getData(); |
| | | FileOutputStream fileOutputStream = null; |
| | | File pictureFile = new File(picturePath); |
| | | fileOutputStream = new FileOutputStream(pictureFile); |
| | | fileOutputStream.write(data); |
| | | |
| | | bomApproving.setPictureUrl(picturePathFront); |
| | | } |
| | | }break; |
| | | } |
| | | } |
| | | list.add(bomApproving); |
| | | } |
| | | }*/ |
| | | } |
| | | return null; |
| | | /*String parentModel = list.get(0).getParentModel(); |
| | | for (int i = 0; i < list.size(); i++) { |
| | | if(!parentModel.equals(list.get(i).getParentModel())){ |
| | | return new Response().set(1,false,"拒绝解析,一次审批包含不同的产品修改"); |
| | | } |
| | | }*/ |
| | | //通过包名,查询工单流程审批标题 |
| | | //String nextTitle = mainService.getNextTitle(originalFilename); |
| | | |
| | | /*//子表,逐条对比bom表,子料编码/子料型号/子料数量 |
| | | for (ProductBomApproving sub:list){ |
| | | String subCode = sub.getSubCode(); |
| | | String subModel = sub.getSubModel(); |
| | | Integer quantity = sub.getQuantity(); |
| | | String excelName = sub.getExcelName(); |
| | | boolean exists = false; |
| | | for (ProductBomApproving reference:bomList){ |
| | | if(subCode.equals(reference.getSubCode())){ |
| | | exists = true; |
| | | if(subModel.equals(reference.getSubModel())){ |
| | | if(quantity.intValue() == reference.getQuantity()){ |
| | | break; |
| | | }else{ |
| | | return response.set(1,false,excelName+"中货品编码:"+subCode+"对应的数量:"+quantity+"在bom表中不正确"); |
| | | } |
| | | }else{ |
| | | return response.set(1,false,excelName+"中货品编码:"+subCode+"对应的规格型号:"+subModel+"在bom表中不正确"); |
| | | } |
| | | } |
| | | } |
| | | if(!exists){ |
| | | return response.set(1,false,excelName+"中货品编码:"+subCode+"在bom表中不存在"); |
| | | } |
| | | }*/ |
| | | /*//处理名称重复的子件 |
| | | List<ProductBomApproving> newBomList = new LinkedList<>(); |
| | | Map<String, List<ProductBomApproving>> subNameMap = bomList.stream().collect(Collectors.groupingBy(ProductBomApproving::getSubName)); |
| | | subNameMap.forEach((subName,approvingList)->{ |
| | | if(approvingList.size()>1){ |
| | | for (int i = 0; i < approvingList.size(); i++) { |
| | | ProductBomApproving bomApproving = approvingList.get(i); |
| | | bomApproving.setSubName(subName+(i+1)); |
| | | newBomList.add(bomApproving); |
| | | } |
| | | }else{ |
| | | newBomList.addAll(approvingList); |
| | | } |
| | | });*/ |
| | | List<ProductBomApproving> collect = bomList.stream().sorted(Comparator.comparing(ProductBomApproving::getId)).collect(Collectors.toList()); |
| | | String nextTitle = originalFilename.substring(0,originalFilename.lastIndexOf(".")); |
| | | return response.setIII(1,true,collect,nextTitle,filePath); |
| | | } |
| | | |
| | | public static void main(String[] args) throws IOException, InvalidFormatException { |
| | | File file = new File("C:\\Users\\29550\\Desktop\\当前项目\\202207图纸管理\\0940000072(BOM).xls"); |
| | | boolean exists = file.exists(); |
| | | System.out.println(exists); |
| | | Workbook workbook = WorkbookFactory.create(file); |
| | | Sheet sheet = workbook.getSheetAt(0); |
| | | int lastRowNum = sheet.getLastRowNum(); |
| | | System.out.println(lastRowNum); |
| | | private List<FileUrlDTO> getDwgList(List<String> fileList) { |
| | | List<FileUrlDTO> list = new LinkedList<>(); |
| | | fileList.forEach(fileUrl->{ |
| | | if(fileUrl.substring(fileUrl.lastIndexOf(".")+1).equals("dwg")) { |
| | | FileUrlDTO dto = new FileUrlDTO(); |
| | | dto.setFileName(fileUrl.substring(fileUrl.lastIndexOf(File.separator) + 1)); |
| | | dto.setHttpFileUrl(fileUrl.substring(fileUrl.lastIndexOf("doc_file" + File.separator + "product_approving"))); |
| | | list.add(dto); |
| | | } |
| | | }); |
| | | return list; |
| | | } |
| | | |
| | | /** |
| | | * |
| | | * @param dwgUrl 预览dwg图纸文件,后追加预览word文档 |
| | | * @return |
| | | * @throws IOException |
| | | */ |
| | | public Response dwgReview(String dwgUrl) throws IOException { |
| | | String fileSuffix = dwgUrl.substring(dwgUrl.lastIndexOf(".") + 1); |
| | | //绝对路径xxx/doc_file |
| | | String rootFile = CommonUtil.getRootFile(); |
| | | String dwgSubFilePath = dwgUrl.substring(dwgUrl.indexOf("doc_file")+8); |
| | | String dwgSubFileDirPath = dwgSubFilePath.substring(0,dwgSubFilePath.lastIndexOf(File.separator)); |
| | | File dwgFile = new File(rootFile + dwgSubFilePath); |
| | | String pdfUrl = ""; |
| | | if(fileSuffix.equals("dwg")) { |
| | | pdfUrl = dwgFile.getParent() + File.separator + dwgFile.getName().substring(0, dwgFile.getName().lastIndexOf(".")) + "-dwg.pdf"; |
| | | }else if(fileSuffix.contains("doc")){ |
| | | pdfUrl = dwgFile.getParent() + File.separator + dwgFile.getName().substring(0, dwgFile.getName().lastIndexOf(".")) + "-doc.pdf"; |
| | | } |
| | | File pdfFile = new File(pdfUrl); |
| | | String pdfFileName = null; |
| | | if(!pdfFile.exists()) { |
| | | if(fileSuffix.equals("dwg")) { |
| | | //pdfFileName = DwgToPdfUtil.dwg2Pdf(dwgFile); |
| | | DwgToPdfUtil.dwg2Pdf(dwgFile); |
| | | }else if(fileSuffix.contains("doc")){ |
| | | Word2PdfAsposeUtil.doc2pdf(dwgFile.getAbsolutePath(),pdfUrl); |
| | | } |
| | | |
| | | }/*else{ |
| | | pdfFileName = pdfFile.getName(); |
| | | }*/ |
| | | pdfFileName = pdfFile.getName(); |
| | | return new Response().set(1,"doc_file"+dwgSubFileDirPath+File.separator+pdfFileName); |
| | | } |
| | | |
| | | public List<ProductBomApproving> getList(Integer productApprovingId) { |
| | | QueryWrapper<ProductBomApproving> query = Wrappers.query(); |
| | | query.eq("product_approving_id",productApprovingId); |
| | | return mapper.selectList(query); |
| | | } |
| | | } |