From 2e15762c816118c334a745360b6dc9620c1f0856 Mon Sep 17 00:00:00 2001
From: 潘志宝 <979469083@qq.com>
Date: 星期三, 07 五月 2025 09:53:11 +0800
Subject: [PATCH] 电网拓扑功率历史(多code)

---
 ansteel-biz/src/main/java/com/iailab/module/ansteel/api/controller/admin/PowerController.java |   95 +++++++++++++++++++++++++++++++++++++++++++++++
 doc/鞍钢数据接口文档_master.doc                                                                       |    0 
 ansteel-biz/src/main/java/com/iailab/module/ansteel/api/dto/PowerNetFactorHisReqDTO.java      |    3 +
 3 files changed, 97 insertions(+), 1 deletions(-)

diff --git a/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/controller/admin/PowerController.java b/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/controller/admin/PowerController.java
index 0640be5..d05948c 100644
--- a/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/controller/admin/PowerController.java
+++ b/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/controller/admin/PowerController.java
@@ -701,7 +701,7 @@
     }
 
     @PostMapping("/net-factor/history")
-    @Operation(summary = "功率因数-根据nodeName获取最近1440min历史数据,月最大,最小值")
+    @Operation(summary = "功率因数-电网拓扑功率历史")
     public CommonResult<PowerHistoryDTO> getPowerHistoryData(@RequestBody PowerNetFactorHisReqDTO dto) {
         log.info("PowerNetFactorHisReqDTO=" + JSONObject.toJSONString(dto));
         PowerHistoryDTO result = new PowerHistoryDTO();
@@ -783,6 +783,99 @@
         return success(result);
     }
 
+    @PostMapping("/net-factor/history-list")
+    @Operation(summary = "功率因数-电网拓扑功率历史(多code)")
+    public CommonResult<LinkedHashMap<String, PowerHistoryDTO>> getPowerHistoryList(@RequestBody PowerNetFactorHisReqDTO dto) {
+        log.info("PowerNetFactorHisReqDTO=" + JSONObject.toJSONString(dto));
+        LinkedHashMap<String, PowerHistoryDTO> result = new LinkedHashMap<>();
+        List<String> nodeCodeList = dto.getNodeCodeList();
+        if (CollectionUtils.isEmpty(nodeCodeList)) {
+            return CommonResult.error(GlobalErrorCodeConstants.BAD_REQUEST);
+        }
+        String queryType = dto.getQueryType();
+        if (StringUtils.isBlank(queryType)) {
+            return CommonResult.error(GlobalErrorCodeConstants.BAD_REQUEST);
+        }
+        Calendar calendar0 = Calendar.getInstance();
+        calendar0.set(Calendar.MILLISECOND, 0);
+        calendar0.set(Calendar.SECOND, 0);
+        Date end0 = dto.getEndTime() == null ? calendar0.getTime() : dto.getEndTime();
+        calendar0.add(Calendar.MINUTE, -1440);
+        Date start0 = dto.getStartTime() == null ? calendar0.getTime() : dto.getStartTime();
+
+        Calendar calendar1 = Calendar.getInstance();
+        calendar1.set(Calendar.DAY_OF_MONTH, 1);
+        calendar1.set(Calendar.HOUR_OF_DAY, 0);
+        calendar1.set(Calendar.MINUTE, 0);
+        calendar1.set(Calendar.SECOND, 0);
+        calendar1.set(Calendar.MILLISECOND, 0);
+        Date start1 = calendar1.getTime();
+
+        List<String> categories = DateUtils.getTimeScale(start0, end0, 60);
+        for (String nodeCode : nodeCodeList) {
+            PowerHistoryDTO powerHistoryDTO = new PowerHistoryDTO();
+            PowerNetFactorQuery powerNetFactorQuery = null;
+            PowerNetFactorEntity powerNetFactorEntity = powerNetFactorService.getByNodeCode(nodeCode);
+            PowerNetDropdownEntity powerNetDropdownEntity = powerNetDropdownService.getByNodeCode(nodeCode);
+            if (powerNetFactorEntity != null) {
+                powerNetFactorQuery = ConvertUtils.sourceToTarget(powerNetFactorEntity, PowerNetFactorQuery.class);
+            } else if (powerNetDropdownEntity != null) {
+                powerNetFactorQuery = ConvertUtils.sourceToTarget(powerNetDropdownEntity, PowerNetFactorQuery.class);
+            }
+            if (powerNetFactorQuery == null) {
+                log.info("powerNetFactor is null");
+                continue;
+            }
+
+            log.info("开始查询,");
+            ApiPointValueQueryDTO apiPointValueQueryDTO = new ApiPointValueQueryDTO();
+            String pointNo = "";
+            switch (queryType.toUpperCase()) {
+                case "P":
+                    pointNo = powerNetFactorQuery.getCurP();
+                    break;
+                case "Q":
+                    pointNo = powerNetFactorQuery.getCurQ();
+                    break;
+                case "COS":
+                    pointNo = powerNetFactorQuery.getCurCos();
+                    break;
+                default:
+                    break;
+            }
+
+            //查询图表
+            apiPointValueQueryDTO.setPointNo(pointNo);
+            apiPointValueQueryDTO.setEnd(end0);
+            apiPointValueQueryDTO.setStart(start0);
+            List<ApiPointValueDTO> chartData = dataPointApi.queryPointHistoryValue(apiPointValueQueryDTO);
+            List<Object[]> dataList = new ArrayList<>();
+            for (ApiPointValueDTO pv : chartData) {
+                Object[] data = new Object[2];
+                data[0] = DateUtils.format(pv.getT(), DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND);
+                data[1] = pv.getV();
+                dataList.add(data);
+            }
+            powerHistoryDTO.setDataList(dataList);
+
+            //查询月最大最小值
+            ApiPointValueQueryDTO apiPointValueQueryDTO1 = new ApiPointValueQueryDTO();
+            apiPointValueQueryDTO1.setStart(start1);
+            apiPointValueQueryDTO1.setEnd(new Date());
+            apiPointValueQueryDTO1.setPointNo(pointNo);
+            List<ApiPointValueDTO> monthChartData = dataPointApi.queryPointHistoryValue(apiPointValueQueryDTO);
+            List<Double> monthValues = new ArrayList<>();
+            if (CollectionUtils.isEmpty(monthChartData)) {
+                monthValues = monthChartData.stream().map(item -> item.getV()).collect(Collectors.toList());
+                powerHistoryDTO.setMax(monthValues.stream().max(Double::compareTo).get());
+                powerHistoryDTO.setMin(monthValues.stream().min(Double::compareTo).get());
+            }
+
+            result.put(nodeCode, powerHistoryDTO);
+        }
+        return success(result);
+    }
+
     @GetMapping("/adjust-factor")
     @Operation(summary = "功率因数-调整后的功率因数与无功倒送量")
     public CommonResult<Map<String, Double>> getPowerAdjustFactor(@RequestParam Map<String, Object> params) {
diff --git a/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/dto/PowerNetFactorHisReqDTO.java b/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/dto/PowerNetFactorHisReqDTO.java
index 8f6e168..4516c11 100644
--- a/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/dto/PowerNetFactorHisReqDTO.java
+++ b/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/dto/PowerNetFactorHisReqDTO.java
@@ -5,6 +5,7 @@
 
 import java.io.Serializable;
 import java.util.Date;
+import java.util.List;
 
 /**
  * @author PanZhibao
@@ -17,6 +18,8 @@
 
     private String nodeCode;
 
+    private List<String> nodeCodeList;
+
     private String queryType;
 
     @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
diff --git "a/doc/\351\236\215\351\222\242\346\225\260\346\215\256\346\216\245\345\217\243\346\226\207\346\241\243_master.doc" "b/doc/\351\236\215\351\222\242\346\225\260\346\215\256\346\216\245\345\217\243\346\226\207\346\241\243_master.doc"
index c5890ad..01b256f 100644
--- "a/doc/\351\236\215\351\222\242\346\225\260\346\215\256\346\216\245\345\217\243\346\226\207\346\241\243_master.doc"
+++ "b/doc/\351\236\215\351\222\242\346\225\260\346\215\256\346\216\245\345\217\243\346\226\207\346\241\243_master.doc"
Binary files differ

--
Gitblit v1.9.3