From 93052fb8b5680f2b40e1fc649b987f2428a33f2c Mon Sep 17 00:00:00 2001
From: 潘志宝 <979469083@qq.com>
Date: 星期四, 24 四月 2025 16:31:17 +0800
Subject: [PATCH] 备煤工序异常溯源定时修改

---
 ansteel-biz/src/main/java/com/iailab/module/ansteel/job/task/RunCokingProdDayTask.java |  115 ++++++++++++++++++++++++++++++++++-----------------------
 1 files changed, 69 insertions(+), 46 deletions(-)

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..539719a 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,31 +1,30 @@
 package com.iailab.module.ansteel.job.task;
 
-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.framework.common.util.date.DateUtils;
+import com.iailab.module.ansteel.coking.entity.CokingProcessConfEntity;
+import com.iailab.module.ansteel.coking.entity.CokingProdDayEntity;
+import com.iailab.module.ansteel.coking.service.CokingProcessConfService;
+import com.iailab.module.ansteel.coking.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;
-import com.iailab.module.model.api.mdk.MdkApi;
-import com.iailab.module.model.api.mdk.dto.MdkScheduleReqDTO;
-import com.iailab.module.model.api.mdk.dto.MdkScheduleRespDTO;
-import com.iailab.module.model.enums.ScheduleTriggerMethodEnum;
-import org.apache.commons.lang3.ObjectUtils;
 import org.apache.commons.lang3.StringUtils;
 import org.slf4j.Logger;
 import org.slf4j.LoggerFactory;
-import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Component;
 import org.springframework.util.CollectionUtils;
 
 import javax.annotation.Resource;
-import java.time.LocalDateTime;
-import java.time.format.DateTimeFormatter;
-import java.util.*;
-import java.util.stream.Collectors;
+import java.util.ArrayList;
+import java.util.Calendar;
+import java.util.List;
+import java.util.Map;
 
 /**
+ * 生成焦化日前生产信息
+ * 0 5 0 * * ?
+ *
  * @author HouZhongjian
  * @Description
  * @createTime 2025年04月12日
@@ -44,45 +43,57 @@
     @Resource
     private DataPointApi dataPointApi;
 
+    @Resource
+    private IndItemApi indItemApi;
+
     @Override
     public void run(String params) {
         logger.info("RunCokingProdDayTask,参数为:{}", params);
         try {
-            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 calendar = Calendar.getInstance();
+            calendar.set(Calendar.MILLISECOND, 0);
+            calendar.set(Calendar.SECOND, 0);
+            calendar.add(Calendar.DAY_OF_YEAR, -1);
+            String clock = DateUtils.format(calendar.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());
+                        if (!CollectionUtils.isEmpty(indValues)) {
+                            value = indValues.get(indValues.size() - 1).getDataValue().toString();
+                        }
+                        break;
+                   default:
+                        break;
+
+                }
+                saveProdDay(conf, value, clock, conf.getIndCode());
+            }
         } catch (Exception ex) {
             logger.error("RunCokingProdDayTask运行异常");
             ex.printStackTrace();
@@ -90,4 +101,16 @@
         logger.info("RunCokingProdDayTask运行完成");
 
     }
+
+    private void saveProdDay(CokingProcessConfEntity conf, String value, String clock, String indCode) {
+        CokingProdDayEntity entity = new CokingProdDayEntity();
+        entity.setInfoType(conf.getInfoType());
+        entity.setSort(conf.getSort());
+        entity.setIndCode(indCode);
+        entity.setIndName(conf.getIndName());
+        entity.setIndUnit(conf.getIndUnit());
+        entity.setIndValue(value);
+        entity.setClock(clock);
+        cokingProdDayService.save(entity);
+    }
 }
\ No newline at end of file

--
Gitblit v1.9.3