From 8c97f18015743c7f913b9c512bdc768d144c575e Mon Sep 17 00:00:00 2001 From: Junjie <fallin.jie@qq.com> Date: 星期三, 31 五月 2023 08:08:05 +0800 Subject: [PATCH] 高频入出库模式 --- src/main/java/com/zy/asrs/utils/Utils.java | 205 +++++++++++++++++++++++++++++++++++++++++--------- 1 files changed, 166 insertions(+), 39 deletions(-) diff --git a/src/main/java/com/zy/asrs/utils/Utils.java b/src/main/java/com/zy/asrs/utils/Utils.java index 3430b72..08060e9 100644 --- a/src/main/java/com/zy/asrs/utils/Utils.java +++ b/src/main/java/com/zy/asrs/utils/Utils.java @@ -6,6 +6,7 @@ import java.text.DecimalFormat; import java.util.ArrayList; +import java.util.Collections; import java.util.List; /** @@ -224,56 +225,180 @@ /** * 鑾峰彇 娣卞簱浣嶅搴旂殑娴呭簱浣嶇粍 */ - public static String[] getShallowLocs(String deepLoc){ - String[] locsArr = null; - String locs=""; - int row = getRow(deepLoc); + public static List<String> getShallowLocs(String locNo){ + int row = getRow(locNo); switch (row){ case 1: - locs += zerofill(String.valueOf(row+2),2) + deepLoc.substring(2); - locs += "," + zerofill(String.valueOf(row+1),2) + deepLoc.substring(2); - break; + return new ArrayList<String>() {{ + add(zerofill(String.valueOf(2), 2) + locNo.substring(2)); + add(zerofill(String.valueOf(3), 2) + locNo.substring(2)); + }}; case 2: - locs += zerofill(String.valueOf(row+1),2) + deepLoc.substring(2); - break; + return new ArrayList<String>() {{ + add(zerofill(String.valueOf(3), 2) + locNo.substring(2)); + }}; + case 3: + case 4: + return null; case 5: - case 20: - locs += zerofill(String.valueOf(row-1),2) + deepLoc.substring(2); - break; + return new ArrayList<String>() {{ + add(zerofill(String.valueOf(4), 2) + locNo.substring(2)); + }}; case 6: - case 14: - case 21: - locs += zerofill(String.valueOf(row-2),2) + deepLoc.substring(2); - locs += "," + zerofill(String.valueOf(row-1),2) + deepLoc.substring(2); - break; + return new ArrayList<String>() {{ + add(zerofill(String.valueOf(5), 2) + locNo.substring(2)); + add(zerofill(String.valueOf(4), 2) + locNo.substring(2)); + }}; case 7: - locs += zerofill(String.valueOf(row-3),2) + deepLoc.substring(2); - locs += "," + zerofill(String.valueOf(row-2),2) + deepLoc.substring(2); - locs += "," + zerofill(String.valueOf(row-1),2) + deepLoc.substring(2); - break; + return new ArrayList<String>() {{ + add(zerofill(String.valueOf(6), 2) + locNo.substring(2)); + add(zerofill(String.valueOf(5), 2) + locNo.substring(2)); + add(zerofill(String.valueOf(4), 2) + locNo.substring(2)); + }}; case 8: - case 15: - locs += zerofill(String.valueOf(row+3),2) + deepLoc.substring(2); - locs += "," + zerofill(String.valueOf(row+2),2) + deepLoc.substring(2); - locs += "," + zerofill(String.valueOf(row+1),2) + deepLoc.substring(2); - break; + return new ArrayList<String>() {{ + add(zerofill(String.valueOf(9), 2) + locNo.substring(2)); + add(zerofill(String.valueOf(10), 2) + locNo.substring(2)); + add(zerofill(String.valueOf(11), 2) + locNo.substring(2)); + }}; case 9: - case 16: - locs += zerofill(String.valueOf(row+2),2) + deepLoc.substring(2); - locs += "," + zerofill(String.valueOf(row+1),2) + deepLoc.substring(2); - break; + return new ArrayList<String>() {{ + add(zerofill(String.valueOf(10), 2) + locNo.substring(2)); + add(zerofill(String.valueOf(11), 2) + locNo.substring(2)); + }}; case 10: - case 17: - locs += zerofill(String.valueOf(row+1),2) + deepLoc.substring(2); - break; + return new ArrayList<String>() {{ + add(zerofill(String.valueOf(11), 2) + locNo.substring(2)); + }}; + case 11: + case 12: + return null; case 13: - locs += zerofill(String.valueOf(row-1),2) + deepLoc.substring(2); - break; + return new ArrayList<String>() {{ + add(zerofill(String.valueOf(12), 2) + locNo.substring(2)); + }}; + case 14: + return new ArrayList<String>() {{ + add(zerofill(String.valueOf(13), 2) + locNo.substring(2)); + add(zerofill(String.valueOf(12), 2) + locNo.substring(2)); + }}; + case 15: + return new ArrayList<String>() {{ + add(zerofill(String.valueOf(16), 2) + locNo.substring(2)); + add(zerofill(String.valueOf(17), 2) + locNo.substring(2)); + add(zerofill(String.valueOf(18), 2) + locNo.substring(2)); + }}; + case 16: + return new ArrayList<String>() {{ + add(zerofill(String.valueOf(17), 2) + locNo.substring(2)); + add(zerofill(String.valueOf(18), 2) + locNo.substring(2)); + }}; + case 17: + return new ArrayList<String>() {{ + add(zerofill(String.valueOf(18), 2) + locNo.substring(2)); + }}; + case 18: + case 19: + return null; + case 20: + return new ArrayList<String>() {{ + add(zerofill(String.valueOf(19), 2) + locNo.substring(2)); + }}; + case 21: + return new ArrayList<String>() {{ + add(zerofill(String.valueOf(20), 2) + locNo.substring(2)); + add(zerofill(String.valueOf(19), 2) + locNo.substring(2)); + }}; + default: + throw new RuntimeException("搴撲綅瑙f瀽寮傚父"); } - if(!Cools.isEmpty(locs)){ - locsArr = locs.split(","); +// String[] locsArr = null; +// String locs=""; +// int row = getRow(deepLoc); +// switch (row){ +// case 1: +// locs += zerofill(String.valueOf(row+2),2) + deepLoc.substring(2); +// locs += "," + zerofill(String.valueOf(row+1),2) + deepLoc.substring(2); +// break; +// case 2: +// locs += zerofill(String.valueOf(row+1),2) + deepLoc.substring(2); +// break; +// case 5: +// case 20: +// locs += zerofill(String.valueOf(row-1),2) + deepLoc.substring(2); +// break; +// case 6: +// case 14: +// case 21: +// locs += zerofill(String.valueOf(row-2),2) + deepLoc.substring(2); +// locs += "," + zerofill(String.valueOf(row-1),2) + deepLoc.substring(2); +// break; +// case 7: +// locs += zerofill(String.valueOf(row-3),2) + deepLoc.substring(2); +// locs += "," + zerofill(String.valueOf(row-2),2) + deepLoc.substring(2); +// locs += "," + zerofill(String.valueOf(row-1),2) + deepLoc.substring(2); +// break; +// case 8: +// case 15: +// locs += zerofill(String.valueOf(row+3),2) + deepLoc.substring(2); +// locs += "," + zerofill(String.valueOf(row+2),2) + deepLoc.substring(2); +// locs += "," + zerofill(String.valueOf(row+1),2) + deepLoc.substring(2); +// break; +// case 9: +// case 16: +// locs += zerofill(String.valueOf(row+2),2) + deepLoc.substring(2); +// locs += "," + zerofill(String.valueOf(row+1),2) + deepLoc.substring(2); +// break; +// case 10: +// case 17: +// locs += zerofill(String.valueOf(row+1),2) + deepLoc.substring(2); +// break; +// case 13: +// locs += zerofill(String.valueOf(row-1),2) + deepLoc.substring(2); +// break; +// } +// if(!Cools.isEmpty(locs)){ +// locsArr = locs.split(","); +// } +// return locsArr; + } + + /** + * 鑾峰彇褰撳墠搴撲綅宸烽亾鏈�澶栦晶搴撲綅鍙� + */ + public static String getGroupOutermostLoc(String locNo) { + int row = getRow(locNo); + switch (row) { + case 1: + case 2: + case 3: + return zerofill(String.valueOf(3), 2) + locNo.substring(2); + case 4: + case 5: + case 6: + case 7: + return zerofill(String.valueOf(4), 2) + locNo.substring(2); + case 8: + case 9: + case 10: + case 11: + return zerofill(String.valueOf(11), 2) + locNo.substring(2); + case 12: + case 13: + case 14: + return zerofill(String.valueOf(12), 2) + locNo.substring(2); + case 15: + case 16: + case 17: + case 18: + return zerofill(String.valueOf(18), 2) + locNo.substring(2); + case 19: + case 20: + case 21: + return zerofill(String.valueOf(19), 2) + locNo.substring(2); + default: + throw new RuntimeException("搴撲綅瑙f瀽寮傚父"); } - return locsArr; } /** @@ -351,8 +476,10 @@ // String deepLocs = getDeepLocs("2100203"); // System.out.println("shallowLocs ==>> " + shallowLocs); // System.out.println("deepLocs ==>> " + deepLocs); - String[] shallowArr = getShallowLocs("1700203");; +// String[] shallowArr = getShallowLocs("0300504"); + List<String> shallowLocs = getShallowLocs("2100404"); String[] deepArr = getDeepLocs("1700203"); + String outermostLoc = getGroupOutermostLoc("0701703"); // if (shallowLocs.indexOf(',') >= 0) { // shallowArr = shallowLocs.split(","); // } -- Gitblit v1.9.1