From 77a744f7d902731f6a572eb47603472b7a915b47 Mon Sep 17 00:00:00 2001 From: psh Date: Tue, 26 Mar 2024 14:21:06 +0800 Subject: [PATCH] =?UTF-8?q?=E6=BB=A1=E6=9E=B6=E4=B8=8B=E6=96=99=E5=A4=9A?= =?UTF-8?q?=E5=88=97=E5=8F=AF=E6=94=BE=E6=97=B6=E4=BC=98=E5=85=88=E6=94=BE?= =?UTF-8?q?=E6=95=B0=E9=87=8F=E6=9C=80=E5=A4=9A=E7=9A=84?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../sch/task_manage/task/tasks/MJXLTask.java | 27 ++++++++++++------- 1 file changed, 18 insertions(+), 9 deletions(-) diff --git a/lms/nladmin-system/nlsso-server/src/main/java/org/nl/wms/sch/task_manage/task/tasks/MJXLTask.java b/lms/nladmin-system/nlsso-server/src/main/java/org/nl/wms/sch/task_manage/task/tasks/MJXLTask.java index 6b52689..683b1bd 100644 --- a/lms/nladmin-system/nlsso-server/src/main/java/org/nl/wms/sch/task_manage/task/tasks/MJXLTask.java +++ b/lms/nladmin-system/nlsso-server/src/main/java/org/nl/wms/sch/task_manage/task/tasks/MJXLTask.java @@ -32,11 +32,7 @@ import org.springframework.context.annotation.Lazy; import org.springframework.stereotype.Component; import java.math.BigDecimal; -import java.util.ArrayList; -import java.util.HashSet; -import java.util.List; -import java.util.Map; -import java.util.Set; +import java.util.*; /** * @Author: psh @@ -134,6 +130,7 @@ public class MJXLTask extends AbstractTask { regionCode = "GHS2"; } List schBasePointList = pointMapper.findPointByRegion(regionCode, "2"); + Map pointMap=new HashMap<>(); for (SchBasePoint schBasePoint : schBasePointList) { if (!schBasePoint.getPoint_code().endsWith("01") && !schBasePoint.getPoint_code().endsWith("06")) { @@ -146,7 +143,8 @@ public class MJXLTask extends AbstractTask { //新增逻辑,同一列只能放相同物料 boolean flag=true; List list=new ArrayList<>(); - for(int i=1;i<=4;i++){ + Integer qty=0; + for(int i=0;i<=4;i++){ int end=Integer.parseInt(schBasePoint.getPoint_code().substring(schBasePoint.getPoint_code().length()-1))+i; String pointCode=schBasePoint.getPoint_code().substring(0,schBasePoint.getPoint_code().length()-1); list.add(pointCode+end); @@ -156,16 +154,27 @@ public class MJXLTask extends AbstractTask { if (ObjectUtil.isNotEmpty(schBasePoint2.getVehicle_type()) && !materialType.equals(schBasePoint2.getVehicle_type())) { flag = false; } + qty+=schBasePoint2.getVehicle_qty(); } } if(!flag){ continue; } - log.info("满架下料找到当前符合条件的点位{}", schBasePoint.getPoint_code()); - return schBasePoint; + log.info("满架下料找到当前符合条件的点位{},当前列总数{}", schBasePoint.getPoint_code(),qty); + pointMap.put(schBasePoint,qty); } } - return null; + SchBasePoint schBasePoint=null; + int qty=0; + Iterator> iterator = pointMap.entrySet().iterator(); + while (iterator.hasNext()){ + Map.Entry next = iterator.next(); + if (next.getValue()>qty){ + qty=next.getValue(); + schBasePoint=next.getKey(); + } + } + return schBasePoint; } @Override