From fc0cd9cb4452d86c47c362f849d3643d23d01d67 Mon Sep 17 00:00:00 2001
From: 潘志宝 <979469083@qq.com>
Date: 星期日, 13 四月 2025 20:05:00 +0800
Subject: [PATCH] 负荷移植建议与方案

---
 ansteel-biz/src/main/java/com/iailab/module/ansteel/api/controller/admin/ModelController.java      |   65 +++++++++++----
 ansteel-biz/src/main/java/com/iailab/module/ansteel/framework/rpc/config/RpcConfiguration.java     |    3 
 ansteel-biz/src/main/java/com/iailab/module/ansteel/common/enums/ProcessConfDataTypeEnum.java      |   34 ++++++++
 doc/鞍钢数据接口文档_master.doc                                                                            |    0 
 ansteel-biz/src/main/java/com/iailab/module/ansteel/api/entity/CokingProcessConfEntity.java        |    4 +
 ansteel-biz/src/main/java/com/iailab/module/ansteel/api/service/CokingProdDayService.java          |    2 
 ansteel-biz/src/main/java/com/iailab/module/ansteel/api/service/impl/CokingProdDayServiceImpl.java |    8 ++
 ansteel-biz/src/main/java/com/iailab/module/ansteel/api/vo/PowerTransferRespVO.java                |    8 +-
 ansteel-biz/src/main/java/com/iailab/module/ansteel/job/task/RunCokingProdDayTask.java             |   86 ++++++++++++++------
 ansteel-biz/src/main/java/com/iailab/module/ansteel/api/vo/PowerTransferReqVO.java                 |    3 
 10 files changed, 162 insertions(+), 51 deletions(-)

diff --git a/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/controller/admin/ModelController.java b/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/controller/admin/ModelController.java
index ef9f535..9278972 100644
--- a/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/controller/admin/ModelController.java
+++ b/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/controller/admin/ModelController.java
@@ -89,33 +89,60 @@
             }
 
             Map<String, Object> data = mdkScheduleRespDTO.getResult();
-            if ("1".equals(reqVO.getType())) {
-                // 高炉休风
-                result.setBestTotalPower(DecimalUtil.toBigDecimal(data.get("best_total_power")));
-                result.setBfgAdvice(DecimalUtil.toBigDecimal(data.get("BFGAdvice")));
-                result.setDemandAdvice(DecimalUtil.toBigDecimal(data.get("DemandAdvice")));
-                result.setJiaohuaAdviceTime(DecimalUtil.toBigDecimal(data.get("jiaohuaAdvice"), 0).intValue());
-                result.setJiaohuaAdviceAmount(DecimalUtil.toBigDecimal(data.get("jiaohuaAdvice"), 1).intValue());
+            switch (TransferTypeEnum.getEumByCode(reqVO.getType())) {
+                case XF:
+                    // 高炉休风
+                    result.setBestTotalPower(DecimalUtil.toBigDecimal(data.get("best_total_power")));//负荷调整总量
+                    result.setBfgGap(DecimalUtil.toBigDecimal(data.get("bfg_gap")));//煤气送管网缺口
+                    result.setDemand(DecimalUtil.toBigDecimal(data.get("demand")));//需量缺口
+                    result.setCogGapTime(data.get("cog_gap") == null ? 0 : DecimalUtil.toBigDecimal(data.get("cog_gap"), 0).intValue()); //焦化减高炉煤气-时间
+                    result.setCogGapAmount(data.get("cog_gap") == null ? 0 : DecimalUtil.toBigDecimal(data.get("cog_gap"), 1).intValue());//焦化减高炉煤气-数量
 
-                adviceList.add(DecimalUtil.toPowerTransferDetRespVO("中板工序", data.get("zhongabnAdvice")));
-                adviceList.add(DecimalUtil.toPowerTransferDetRespVO("厚板工序", data.get("houbanAdvice")));
-                adviceList.add(DecimalUtil.toPowerTransferDetRespVO("热轧工序", data.get("rezhaAdvice")));
-                adviceList.add(DecimalUtil.toPowerTransferDetRespVO("白灰工序", data.get("baihuiAdvice")));
-                adviceList.add(DecimalUtil.toPowerTransferDetRespVO("3#制氧机", data.get("zhiyangAdvice")));
-                adviceList.add(DecimalUtil.toPowerTransferDetRespVO("1#LF炉", data.get("1LFAdvice")));
-                adviceList.add(DecimalUtil.toPowerTransferDetRespVO("2#LF炉", data.get("2LFAdvice")));
-                adviceList.add(DecimalUtil.toPowerTransferDetRespVO("B系列烧结", data.get("shaojieAdvice")));
-                adviceList.add(DecimalUtil.toPowerTransferDetRespVO("CCPP", data.get("CCPPAdvice")));
+                    if (data.get("zhongabnAdvice") != null) {
+                        adviceList.add(DecimalUtil.toPowerTransferDetRespVO("中板工序", data.get("zhongabnAdvice")));
+                    }
+                    if (data.get("houbanAdvice") != null) {
+                        adviceList.add(DecimalUtil.toPowerTransferDetRespVO("厚板工序", data.get("houbanAdvice")));
+                    }
+                    if (data.get("rezhaAdvice") != null) {
+                        adviceList.add(DecimalUtil.toPowerTransferDetRespVO("热轧工序", data.get("rezhaAdvice")));
+                    }
+                    if (data.get("baihuiAdvice") != null) {
+                        adviceList.add(DecimalUtil.toPowerTransferDetRespVO("白灰工序", data.get("baihuiAdvice")));
+                    }
+                    if (data.get("zhiyangAdvice") != null) {
+                        adviceList.add(DecimalUtil.toPowerTransferDetRespVO("3#制氧机", data.get("zhiyangAdvice")));
+                    }
+                    if (data.get("1LFAdvice") != null) {
+                        adviceList.add(DecimalUtil.toPowerTransferDetRespVO("1#LF炉", data.get("1LFAdvice")));
+                    }
+                    if (data.get("2LFAdvice") != null) {
+                        adviceList.add(DecimalUtil.toPowerTransferDetRespVO("2#LF炉", data.get("2LFAdvice")));
+                    }
+                    if (data.get("shaojieAdvice") != null) {
+                        adviceList.add(DecimalUtil.toPowerTransferDetRespVO("B系列烧结", data.get("shaojieAdvice")));
+                    }
+                    if (data.get("shaojieAdvice") != null) {
+                        adviceList.add(DecimalUtil.toPowerTransferDetRespVO("CCPP", data.get("CCPPAdvice")));
+                    }
+                    result.setAdviceList(adviceList);
+                    log.info("XFXFXFXFXFXFXFXFXFXFXFXFXFXFXFXFXFXFXF");
+                    break;
+               case JX:
+                   // 产线检修
 
-            } else if ("2".equals(reqVO.getType())) {
-                // 产线检修
+                   log.info("JXJXJXJXJXJXJXJXJXJXJXJXJXJXJXJXJXJXJXJX");
+                    break;
+               default:
+
+                    break;
 
             }
-
         } catch (Exception ex) {
             ex.printStackTrace();
             return CommonResult.error(GlobalErrorCodeConstants.UNKNOWN.getCode(), ex.getMessage());
         }
+        log.info("result=" + JSONObject.toJSONString(result));
         return CommonResult.success(result);
     }
 }
\ No newline at end of file
diff --git a/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/entity/CokingProcessConfEntity.java b/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/entity/CokingProcessConfEntity.java
index 6c72e35..b4288f9 100644
--- a/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/entity/CokingProcessConfEntity.java
+++ b/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/entity/CokingProcessConfEntity.java
@@ -28,6 +28,10 @@
      */
     private String indType;
     /**
+     * 数据类型
+     */
+    private String dataType;
+    /**
      * 测点编码
      */
     private String pointNo;
diff --git a/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/service/CokingProdDayService.java b/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/service/CokingProdDayService.java
index 598b34b..ccd683e 100644
--- a/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/service/CokingProdDayService.java
+++ b/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/service/CokingProdDayService.java
@@ -15,4 +15,6 @@
     List<CokingProdDayEntity> list(Map<String, Object> params);
 
     void save(CokingProdDayEntity entity);
+
+    void deleteByClock(String clock);
 }
\ No newline at end of file
diff --git a/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/service/impl/CokingProdDayServiceImpl.java b/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/service/impl/CokingProdDayServiceImpl.java
index 34eefe6..c0f065a 100644
--- a/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/service/impl/CokingProdDayServiceImpl.java
+++ b/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/service/impl/CokingProdDayServiceImpl.java
@@ -44,4 +44,12 @@
     public void save(CokingProdDayEntity entity) {
         cokingProdDayDao.insert(entity);
     }
+
+    @Override
+    public void deleteByClock(String clock) {
+        QueryWrapper<CokingProdDayEntity> queryWrapper = new QueryWrapper<>();
+        queryWrapper.eq("clock", clock);
+        cokingProdDayDao.delete(queryWrapper);
+
+    }
 }
\ No newline at end of file
diff --git a/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/vo/PowerTransferReqVO.java b/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/vo/PowerTransferReqVO.java
index aba6d93..6f02645 100644
--- a/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/vo/PowerTransferReqVO.java
+++ b/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/vo/PowerTransferReqVO.java
@@ -19,6 +19,9 @@
     @Schema(description = "异常工况类型(1:高炉休风;2:产线检修)")
     private Integer type;
 
+    @Schema(description = "当前时间")
+    private Integer now;
+
     @Schema(description = "休风开始时间")
     private Integer start;
 
diff --git a/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/vo/PowerTransferRespVO.java b/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/vo/PowerTransferRespVO.java
index b95d138..dffe791 100644
--- a/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/vo/PowerTransferRespVO.java
+++ b/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/vo/PowerTransferRespVO.java
@@ -22,16 +22,16 @@
     private BigDecimal bestTotalPower;
 
     @Schema(description = "煤气送管网缺口")
-    private BigDecimal bfgAdvice;
+    private BigDecimal bfgGap;
 
     @Schema(description = "需量缺口")
-    private BigDecimal demandAdvice;
+    private BigDecimal demand;
 
     @Schema(description = "焦化减高炉煤气-时间")
-    private Integer jiaohuaAdviceTime;
+    private Integer cogGapTime;
 
     @Schema(description = "焦化减高炉煤气-数量")
-    private Integer jiaohuaAdviceAmount;
+    private Integer cogGapAmount;
 
     @Schema(description = "建议列表")
     private List<PowerTransferDetRespVO> adviceList;
diff --git a/ansteel-biz/src/main/java/com/iailab/module/ansteel/common/enums/ProcessConfDataTypeEnum.java b/ansteel-biz/src/main/java/com/iailab/module/ansteel/common/enums/ProcessConfDataTypeEnum.java
new file mode 100644
index 0000000..7b4da9b
--- /dev/null
+++ b/ansteel-biz/src/main/java/com/iailab/module/ansteel/common/enums/ProcessConfDataTypeEnum.java
@@ -0,0 +1,34 @@
+package com.iailab.module.ansteel.common.enums;
+
+import lombok.AllArgsConstructor;
+import lombok.Getter;
+
+/**
+ * @author PanZhibao
+ * @Description
+ * @createTime 2025年04月13日
+ */
+@Getter
+@AllArgsConstructor
+public enum ProcessConfDataTypeEnum {
+    DATAPOINT("DATAPOINT", "测点值"),
+    IND("IND", "指标值(double)"),
+    IND_ASCII("IND_ASCII", "指标值(ASCII)"),
+    PLAN("PLAN", "计划值");
+
+    private String code;
+    private String desc;
+
+    public static ProcessConfDataTypeEnum getEumByCode(String code) {
+        if (code == null) {
+            return null;
+        }
+
+        for (ProcessConfDataTypeEnum statusEnum : ProcessConfDataTypeEnum.values()) {
+            if (statusEnum.getCode().equals(code)) {
+                return statusEnum;
+            }
+        }
+        return null;
+    }
+}
\ No newline at end of file
diff --git a/ansteel-biz/src/main/java/com/iailab/module/ansteel/framework/rpc/config/RpcConfiguration.java b/ansteel-biz/src/main/java/com/iailab/module/ansteel/framework/rpc/config/RpcConfiguration.java
index 89c7a4b..8d5a337 100644
--- a/ansteel-biz/src/main/java/com/iailab/module/ansteel/framework/rpc/config/RpcConfiguration.java
+++ b/ansteel-biz/src/main/java/com/iailab/module/ansteel/framework/rpc/config/RpcConfiguration.java
@@ -1,5 +1,6 @@
 package com.iailab.module.ansteel.framework.rpc.config;
 
+import com.iailab.module.data.api.ind.IndItemApi;
 import com.iailab.module.data.api.plan.PlanItemApi;
 import com.iailab.module.data.api.point.DataPointApi;
 import com.iailab.module.infra.api.config.ConfigApi;
@@ -13,6 +14,6 @@
 import org.springframework.context.annotation.Configuration;
 
 @Configuration(proxyBeanMethods = false)
-@EnableFeignClients(clients = {FileApi.class, WebSocketSenderApi.class, DataSourceConfigServiceApi.class, ConfigApi.class, TenantApi.class, McsApi.class, MdkApi.class, DataPointApi.class, PlanItemApi.class})
+@EnableFeignClients(clients = {FileApi.class, WebSocketSenderApi.class, DataSourceConfigServiceApi.class, ConfigApi.class, TenantApi.class, McsApi.class, MdkApi.class, DataPointApi.class, PlanItemApi.class, IndItemApi.class})
 public class RpcConfiguration {
 }
diff --git a/ansteel-biz/src/main/java/com/iailab/module/ansteel/job/task/RunCokingProdDayTask.java b/ansteel-biz/src/main/java/com/iailab/module/ansteel/job/task/RunCokingProdDayTask.java
index 6edc964..6b3a765 100644
--- a/ansteel-biz/src/main/java/com/iailab/module/ansteel/job/task/RunCokingProdDayTask.java
+++ b/ansteel-biz/src/main/java/com/iailab/module/ansteel/job/task/RunCokingProdDayTask.java
@@ -1,9 +1,13 @@
 package com.iailab.module.ansteel.job.task;
 
+import com.iailab.framework.common.util.date.DateUtils;
 import com.iailab.module.ansteel.api.entity.CokingProcessConfEntity;
 import com.iailab.module.ansteel.api.entity.CokingProdDayEntity;
 import com.iailab.module.ansteel.api.service.CokingProcessConfService;
 import com.iailab.module.ansteel.api.service.CokingProdDayService;
+import com.iailab.module.ansteel.common.enums.ProcessConfDataTypeEnum;
+import com.iailab.module.data.api.ind.IndItemApi;
+import com.iailab.module.data.api.ind.dto.ApiIndItemValueDTO;
 import com.iailab.module.data.api.point.DataPointApi;
 import com.iailab.module.model.api.mcs.McsApi;
 import com.iailab.module.model.api.mcs.dto.StScheduleSchemeDTO;
@@ -26,6 +30,9 @@
 import java.util.stream.Collectors;
 
 /**
+ * 生成焦化日前生产信息
+ * 0 5 0 * * ?
+ *
  * @author HouZhongjian
  * @Description
  * @createTime 2025年04月12日
@@ -44,6 +51,9 @@
     @Resource
     private DataPointApi dataPointApi;
 
+    @Resource
+    private IndItemApi indItemApi;
+
     @Override
     public void run(String params) {
         logger.info("RunCokingProdDayTask,参数为:{}", params);
@@ -51,38 +61,49 @@
             Calendar calendar = Calendar.getInstance();
             calendar.set(Calendar.MILLISECOND, 0);
             calendar.set(Calendar.SECOND, 0);
+
             CokingProcessConfEntity queryParams = new CokingProcessConfEntity();
             queryParams.setIndType("prod_day");
             List<CokingProcessConfEntity> list = cokingProcessConfService.list(queryParams);
-            if (ObjectUtils.isNotEmpty(list)) {
-//                List<String> points = list.stream().map(CokingProcessConfEntity::getIndCode).collect(Collectors.toList());
-//                Map<String, Object> stringObjectMap = dataPointApi.queryPointsRealValue(points);
-                // 获取当前日期时间
-                LocalDateTime now = LocalDateTime.now();
-                // 减去一天得到昨天同一时间
-                LocalDateTime yesterday = now.minusDays(1);
-                // 格式化输出
-                DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd");
-                String formattedDateTime = yesterday.format(formatter);
-
-                list.stream().forEach(cokingProcessConfEntity -> {
-                    List<String> points = new ArrayList<>();
-                    points.add(cokingProcessConfEntity.getPointNo());
-                    Map<String, Object> stringObjectMap = dataPointApi.queryPointsRealValue(points);
-                    //保存数据
-                    if(ObjectUtils.isNotEmpty(stringObjectMap.get(cokingProcessConfEntity.getPointNo()))) {
-                        CokingProdDayEntity cokingProdDayEntity = new CokingProdDayEntity();
-                        cokingProdDayEntity.setInfoType("0");
-                        cokingProdDayEntity.setSort(cokingProcessConfEntity.getSort());
-                        cokingProdDayEntity.setIndName(cokingProcessConfEntity.getIndName());
-                        cokingProdDayEntity.setIndUnit(cokingProcessConfEntity.getIndUnit());
-                        cokingProdDayEntity.setIndValue(stringObjectMap.get(cokingProcessConfEntity.getPointNo()).toString());
-                        cokingProdDayEntity.setClock(formattedDateTime);
-                        cokingProdDayService.save(cokingProdDayEntity);
-                    }
-                });
+            if (CollectionUtils.isEmpty(list)) {
+                logger.info("ConfLis is Empty");
+                return;
             }
 
+            Calendar calendar1 = Calendar.getInstance();
+            calendar1.set(Calendar.MILLISECOND, 0);
+            calendar1.set(Calendar.SECOND, 0);
+            calendar1.add(Calendar.DAY_OF_YEAR, -1);
+            String clock = DateUtils.format(calendar1.getTime(), DateUtils.FORMAT_YEAR_MONTH_DAY);
+            logger.info("清理旧数据");
+            cokingProdDayService.deleteByClock(clock);
+            for (CokingProcessConfEntity conf : list) {
+                if (StringUtils.isBlank(conf.getDataType())) {
+                    logger.info("DataType is Empty");
+                    continue;
+                }
+                if (StringUtils.isBlank(conf.getPointNo())) {
+                    logger.info("PointNo is Empty");
+                    continue;
+                }
+                String value = "";
+                switch (ProcessConfDataTypeEnum.getEumByCode(conf.getDataType())) {
+                    case DATAPOINT:
+                        List<String> points = new ArrayList<>();
+                        points.add(conf.getPointNo());
+                        Map<String, Object> pointsRealValue = dataPointApi.queryPointsRealValue(points);
+                        value = pointsRealValue.get(conf.getPointNo()).toString();
+                        break;
+                    case IND:
+                        List<ApiIndItemValueDTO> indValues = indItemApi.queryIndItemDefaultValue(conf.getPointNo());
+                        break;
+                   default:
+                        break;
+
+                }
+
+                this.saveProdDay(conf, value, clock);
+            }
         } catch (Exception ex) {
             logger.error("RunCokingProdDayTask运行异常");
             ex.printStackTrace();
@@ -90,4 +111,15 @@
         logger.info("RunCokingProdDayTask运行完成");
 
     }
+
+    private void saveProdDay(CokingProcessConfEntity conf, String value, String clock) {
+        CokingProdDayEntity cokingProdDayEntity = new CokingProdDayEntity();
+        cokingProdDayEntity.setInfoType(conf.getInfoType());
+        cokingProdDayEntity.setSort(conf.getSort());
+        cokingProdDayEntity.setIndName(conf.getIndName());
+        cokingProdDayEntity.setIndUnit(conf.getIndUnit());
+        cokingProdDayEntity.setIndValue(value);
+        cokingProdDayEntity.setClock(clock);
+        cokingProdDayService.save(cokingProdDayEntity);
+    }
 }
\ No newline at end of file
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 0682a19..2a75e04 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