From 3793ba4a9b6be8faa6df0d4a76c06763ac03f873 Mon Sep 17 00:00:00 2001
From: zouyu <2723363702@qq.com>
Date: 星期三, 29 十月 2025 15:06:04 +0800
Subject: [PATCH] 外购成品报检相关问题调整

---
 cnas-device/src/main/java/com/ruoyi/device/utils/DataAcquisition.java |  130 +++++++++++++++++++++++++++++++------------
 1 files changed, 94 insertions(+), 36 deletions(-)

diff --git a/cnas-device/src/main/java/com/ruoyi/device/utils/DataAcquisition.java b/cnas-device/src/main/java/com/ruoyi/device/utils/DataAcquisition.java
index 98c04ec..751b778 100644
--- a/cnas-device/src/main/java/com/ruoyi/device/utils/DataAcquisition.java
+++ b/cnas-device/src/main/java/com/ruoyi/device/utils/DataAcquisition.java
@@ -7,7 +7,11 @@
 import com.alibaba.fastjson.JSONObject;
 import com.baomidou.mybatisplus.core.toolkit.ObjectUtils;
 import com.baomidou.mybatisplus.core.toolkit.StringUtils;
+import com.ruoyi.common.core.domain.Result;
+import com.ruoyi.common.utils.RedisUtil;
+import com.ruoyi.device.constant.DCResistanceMqttConstants;
 import com.ruoyi.device.dto.DeviceCollectionDto;
+import com.ruoyi.device.mapper.CollectBridgeMapper;
 import com.ruoyi.device.pojo.DataConfig;
 import com.ruoyi.device.pojo.Device;
 import com.ruoyi.framework.exception.ErrorException;
@@ -24,6 +28,8 @@
 import java.util.regex.Pattern;
 import java.util.stream.Collectors;
 
+import static com.ruoyi.framework.datasource.DynamicDataSourceContextHolder.log;
+
 public class DataAcquisition {
 
     private static final String HTTP = "http://";
@@ -36,6 +42,8 @@
 
     public static final String frequency = "frequency";
 
+    private CollectBridgeMapper collectBridgeMapper;
+
     /**
      * 鏁伴噰鍏ュ彛
      *
@@ -43,7 +51,7 @@
      * @param device
      * @return
      */
-    public static Map<String, Object> dataAcquisitionEntrance(List<DataConfig> dataConfig, Device device, String entrustCode, String sampleCode, String ip, String cableTag) {
+    public static Map<String, Object> dataAcquisitionEntrance(List<DataConfig> dataConfig, Device device, String entrustCode, String sampleCode, String ip, String cableTag, String dbUserName, String dbPassword,String dbTable) {
         // 鍒ゆ柇鏄惁鏄奖鍍忔祴閲忎华
         if (device.getManagementNumber().equals("JCZX-ZB-OP07001")) {
             if (device.getFileType().equals(".xlsx")) {
@@ -69,19 +77,24 @@
          * mdbEntrustCode mdb鏂囦欢闇�瑕侊細濮旀墭缂栧彿瀛楁 涓轰粈涔堟病鏈夊幓杩欎釜mdb鍓嶇紑鍛紵鍥犱负宸茬粡缁欏鎴风殑閮ㄥ垎鐢佃剳涓婂畨瑁呬簡閲囬泦鍣紝鑰岀敤鎴蜂笉鎺ュ彈閲嶆柊瀹夎閲囬泦鍣紝鎵�浠ュ氨娌℃湁鍘婚櫎
          * mdbSampleCode mdb鏂囦欢闇�瑕侊細鏍峰搧缂栧彿瀛楁
          */
+        String mdbEntrustCode = StringUtils.isNotBlank(device.getEntrustCode())?device.getEntrustCode():"";
+        String mdbSampleCode = StringUtils.isNotBlank(device.getSampleCode())?device.getSampleCode():"";
+        String dbFileName = StringUtils.isNotBlank(device.getDbFileName())?device.getDbFileName():"";
         String http = HTTP + ip + GETFILE +
                 "?filePath=" + device.getCollectUrl() +
                 "&fileExtension=" + device.getFileType() +
                 "&entrustCode=" + entrustCode +
                 "&sampleCode=" + sampleCode +
-                "&mdbEntrustCode=" + device.getEntrustCode() +
-                "&mdbSampleCode=" + device.getSampleCode() +
-                "&dbFileName=" + device.getDbFileName();
+                "&mdbEntrustCode=" + mdbEntrustCode +
+                "&mdbSampleCode=" + mdbSampleCode +
+                "&dbFileName=" + dbFileName +
+                "&dbUserName=" + dbUserName +
+                "&dbPassword=" + dbPassword +
+                "&dbTable=" + dbTable;
         System.out.println("璇锋眰鐨� URL: " + http);
         String result = null;
         try {
             result = HttpUtil.get(http);
-            System.out.println("璇锋眰杩斿洖缁撴灉: " + result);
         } catch (IORuntimeException e) {
             e.printStackTrace();
             throw new ErrorException("鎵�鍦ㄧ數鑴戞湭瀹夎鎴栨湭鍚姩锛歀IMS鏂囦欢閲囬泦鍣紒");
@@ -94,7 +107,7 @@
                 throw new ErrorException(jsonObject.get("msg") + "");
             }
         } else {
-            String data = jsonObject.get("data") + "";
+             String data = jsonObject.get("data") + "";
             // 鑰冭檻鍒颁竴涓娴嬮」鍙兘浼氬瓨鍦ㄥ涓暟閲囬厤缃紝鎵�浠ラ渶瑕佽繘琛屽垎缁�
             Map<String, List<DataConfig>> userMap = dataConfig.stream()
                     .peek(i -> {
@@ -134,11 +147,19 @@
                     }
                     break;
                 case ".db":
+//                    map = analysisDb1(data, userMap, device);
+                    map = analysisDb(data, userMap, device);
+                    break;
+                case ".mysql":
+//                    map = analysisDb1(data, userMap, device);
                     map = analysisDb(data, userMap, device);
                     break;
                 case ".png":
                     map = readPngString(data, userMap, device);
                     break;
+//                case ".mqtt":
+//                    map = getActualResistanceValueAsMap(userMap, device);
+//                    break;
                 default:
                     map = null;
                     break;
@@ -151,6 +172,7 @@
             return map;
         }
     }
+
 
     public static Map<String, Object> createFrequency(String entrustCode, String sampleCode, Map<String, Object> map) {
         Set<String> set = new LinkedHashSet<>();
@@ -187,6 +209,56 @@
 
         return "1";
     }
+    private static Map<String, Object> analysisDb1(String data, Map<String, List<DataConfig>> dataConfig, Device device) {
+        JSONObject jsonObject = JSON.parseObject(data);
+        Map<String, Object> map = new HashMap<>();
+        if (jsonObject.isEmpty()) {
+            return map;
+        }
+        // 浠� JSON 鏁版嵁涓彁鍙� data 鏁扮粍
+        JSONArray dataList = JSONArray.parseArray(jsonObject.get("data").toString());
+        dataConfig.forEach((k, v) -> {
+            AtomicInteger numberOfDataEntries = new AtomicInteger();
+            List<Object> list = new ArrayList<>();
+            for (int config = 0; config < v.size(); config++) {
+                String refery = getRefer(v.get(config).getRefery());
+                for (int i = 0; i < dataList.size(); i++) {
+                    JSONObject jsonObject1 = JSON.parseObject(dataList.get(i).toString());
+//                    if (ObjectUtils.isNotEmpty(jsonObject1.get(refery))) {
+//                        numberOfDataEntries.addAndGet(1);
+//                        list.add(jsonObject1.get(refery));
+//                    }
+                    Object o = jsonObject1.get(refery);
+                    if (ObjectUtils.isNotEmpty(o)) {
+                        numberOfDataEntries.addAndGet(1);
+                        list.add(o);
+                    }
+                }
+            }
+            // 鎷兼帴鏁伴噰閰嶇疆
+            List<Object> result = new ArrayList<>();
+            for (int i = 0; i < numberOfDataEntries.get(); i++) {
+                StringBuilder aggregate = new StringBuilder();
+                for (int j = 0; j < v.size(); j++) {
+                    int index;
+                    if (j == 0) {
+                        index = i;
+                    } else {
+                        index = numberOfDataEntries.get() + i;
+                    }
+                    aggregate.append(list.get(index).toString()).append(",");
+                }
+                if (aggregate.length() > 0) {
+                    aggregate.setLength(aggregate.length() - 1);
+                }
+                result.add(aggregate.toString());
+            }
+            // 杩涜鍏紡璁$畻
+            Object resultValue = calculationFormula(result, v.get(0), k, device);
+            map.put(k, resultValue);
+        });
+        return map;
+    }
 
     /**
      * 闇�瑕侀�氳繃X,Y杞村畾浣�
@@ -195,17 +267,20 @@
      * @param dataConfig
      * @return
      */
+
     private static Map<String, Object> analysisDb(String data, Map<String, List<DataConfig>> dataConfig, Device device) {
         JSONObject jsonObject = JSON.parseObject(data);
         Map<String, Object> map = new HashMap<>();
         if (jsonObject.isEmpty()) {
             return map;
         }
+        // 浠� JSON 鏁版嵁涓彁鍙� data 鏁扮粍
         JSONArray dataList = JSONArray.parseArray(jsonObject.get("data").toString());
         dataConfig.forEach((k, v) -> {
             AtomicInteger numberOfDataEntries = new AtomicInteger();
             List<Object> list = new ArrayList<>();
             for (int config = 0; config < v.size(); config++) {
+//                String refery = v.get(config).getRefery();
                 String refery = getRefer(v.get(config).getRefery());
                 for (int i = 0; i < dataList.size(); i++) {
                     JSONObject jsonObject1 = JSON.parseObject(dataList.get(i).toString());
@@ -418,7 +493,7 @@
      * @param dataConfig 瀛樺偍鍏紡鐨勫璞�
      * @return
      */
-    private static Object calculationFormula(List<Object> list, DataConfig dataConfig, String insProductItem, Device device) {
+    public static Object calculationFormula(List<Object> list, DataConfig dataConfig, String insProductItem, Device device) {
         if (list.size() == 0) {
             Map<String, Object> hashMap = new HashMap<>();
             hashMap.put("equipName", device.getDeviceName());
@@ -445,10 +520,10 @@
             listResult.addAll(list);
         }
         // 涓轰簡缁欏墠绔仛鏁版嵁鍖哄垎
-        if (listResult.size() > 1) {
+        if (listResult.size() >= 1) {
             hashMap.put("result", listResult);
         } else {
-            hashMap.put("result", listResult.get(0).toString());
+            hashMap.put("result", listResult);
         }
         hashMap.put("equipName", device.getDeviceName());
         hashMap.put("equipValue", device.getManagementNumber());
@@ -546,24 +621,7 @@
         });
         return map;
     }
-    public static Map<String, Object> analysisList1(String data, Map<String, List<DataConfig>> dataConfig,
-                                                   Device device, String entrustCode, String sampleCode) {
-        Map<String, Object> map = new HashMap<>();
-        dataConfig.forEach((k, v) -> {
-            List<Object> list = new ArrayList<>();
-            // 濮旀墭缂栧彿涓庢牱鍝佺紪鍙蜂笉瀛樺湪锛屽畾锛�1銆乊瀹氳寖鍥达紝X瀹氭í鍧愭爣锛�2銆佸彧瀛樺湪Y锛�3銆佸彧瀛樺湪X
-            if (ObjectUtils.isEmpty(device.getEntrustCode()) && ObjectUtils.isEmpty(device.getSampleCode())) {
-                list = analyzeData(data, v, k, splitIdentifier);
-                // 濮旀墭缂栧彿涓庢牱鍝佺紪鍙峰瓨鍦�
-            } else if (ObjectUtils.isNotEmpty(device.getEntrustCode()) && ObjectUtils.isNotEmpty(device.getSampleCode())) {
-                list = analyzeDataEntrustCodAndSampleCode(data, v, k, splitIdentifier, device, entrustCode, sampleCode);
-            }
-            // 杩涜鍏紡璁$畻
-            Object resultValue = calculationFormula(list, v.get(0), k, device);
-            map.put(k, resultValue);
-        });
-        return map;
-    }
+
     private static List<Object> analyzeDataEntrustCodAndSampleCode(String data, List<DataConfig> v, String k, String splitIdentifier,
                                                                    Device device, String entrustCodeValue, String sampleCodeValue) {
         entrustCodeValue = entrustCodeValue.replaceAll(" ", "");
@@ -646,7 +704,7 @@
     }
 
     // 闃叉鍙傜収鐗╀负绌烘姤閿欙紝杩涜鍒ゆ柇濡傛灉涓虹┖璧嬪�肩┖瀛楃
-    private static String getRefer(String refer) {
+    public static String getRefer(String refer) {
         return ObjectUtils.isNotEmpty(refer) ? refer.replaceAll(" ", "") : "";
     }
     /**
@@ -783,7 +841,7 @@
                 continue;
             }
             // 鏈�缁堢粨鏋�
-//            List<Object> result = new ArrayList<>();
+            List<Object> result = new ArrayList<>();
             // 閫氳繃\n灏嗗瓧绗︿覆鍒嗗壊涓鸿
             String[] aColumnY = data.replaceAll(" ", "").split("\n");
             Integer end = null;
@@ -807,7 +865,7 @@
                             }
                             try {
 //                                System.out.println("----------");
-                                list.add(split1[j]);
+                                result.add(split1[j]);
 
                             } catch (Exception e) {
                                 throw new ErrorException(k + "锛歑杞村畾浣嶈秴鍑猴紒");
@@ -831,7 +889,7 @@
                             if (aLineX[j].contains(referx)) {
                                 try {
 //                                    System.out.println("77777777777777");
-                                    list.add(aLineX[j + x]);
+                                    result.add(aLineX[j + x]);
                                 } catch (Exception e) {
                                     throw new ErrorException(k + "锛歑杞村畾浣嶈秴鍑猴紒");
                                 }
@@ -848,7 +906,7 @@
                         if (aLineX[j].contains(referx)) {
                             try {
 //                                System.out.println("4444444444444444");
-                                list.add(aLineX[j + x]);
+                                result.add(aLineX[j + x]);
                             } catch (Exception e) {
                                 throw new ErrorException(k + "锛歑杞村畾浣嶈秴鍑猴紒");
                             }
@@ -856,11 +914,11 @@
                     }
                 }
             }
-            // 闃叉璁$畻鍏紡鐨勬椂鍊欏嚭鐜帮細[null] 杩欑鏁版嵁
-//            if (ObjectUtils.isNotEmpty(result)) {
+//             闃叉璁$畻鍏紡鐨勬椂鍊欏嚭鐜帮細[null] 杩欑鏁版嵁
+            if (ObjectUtils.isNotEmpty(result)) {
 //                String formatProcessing = getFormatProcessing(result);
-//                list.addAll(result);
-//            }
+                list.addAll(result);
+            }
         }
         return list;
     }

--
Gitblit v1.9.3