|
@@ -2,10 +2,14 @@ package com.gyee.runeconomy.service.auto.impl;
|
|
|
|
|
|
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
|
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
|
import com.baomidou.mybatisplus.core.toolkit.StringUtils;
|
|
import com.baomidou.mybatisplus.core.toolkit.StringUtils;
|
|
|
|
+import com.fasterxml.jackson.databind.ObjectMapper;
|
|
import com.gyee.runeconomy.config.GyeeConfig;
|
|
import com.gyee.runeconomy.config.GyeeConfig;
|
|
|
|
+import com.gyee.runeconomy.dto.AlarmDataParser;
|
|
import com.gyee.runeconomy.dto.FiveLoss.AnnotationTool;
|
|
import com.gyee.runeconomy.dto.FiveLoss.AnnotationTool;
|
|
import com.gyee.runeconomy.dto.FiveLoss.FixedVo;
|
|
import com.gyee.runeconomy.dto.FiveLoss.FixedVo;
|
|
import com.gyee.runeconomy.dto.FiveLoss.TableTitle;
|
|
import com.gyee.runeconomy.dto.FiveLoss.TableTitle;
|
|
|
|
+import com.gyee.runeconomy.dto.fitting.Alarm;
|
|
|
|
+import com.gyee.runeconomy.dto.fitting.AlarmDataVo;
|
|
import com.gyee.runeconomy.dto.result.PowerPointData;
|
|
import com.gyee.runeconomy.dto.result.PowerPointData;
|
|
import com.gyee.runeconomy.dto.speed.WindDirectionALG;
|
|
import com.gyee.runeconomy.dto.speed.WindDirectionALG;
|
|
import com.gyee.runeconomy.init.CacheContext;
|
|
import com.gyee.runeconomy.init.CacheContext;
|
|
@@ -13,16 +17,22 @@ import com.gyee.runeconomy.model.LineCurveFitting;
|
|
import com.gyee.runeconomy.model.PowerFittingALG;
|
|
import com.gyee.runeconomy.model.PowerFittingALG;
|
|
import com.gyee.runeconomy.model.PowerFittingData;
|
|
import com.gyee.runeconomy.model.PowerFittingData;
|
|
import com.gyee.runeconomy.model.PowerProcessALG;
|
|
import com.gyee.runeconomy.model.PowerProcessALG;
|
|
|
|
+import com.gyee.runeconomy.model.auto.ProBasicEquipment;
|
|
import com.gyee.runeconomy.model.auto.ProBasicEquipmentPoint;
|
|
import com.gyee.runeconomy.model.auto.ProBasicEquipmentPoint;
|
|
import com.gyee.runeconomy.model.auto.ProBasicModelPower;
|
|
import com.gyee.runeconomy.model.auto.ProBasicModelPower;
|
|
import com.gyee.runeconomy.model.auto.ProEconPowerFittingAnalySis;
|
|
import com.gyee.runeconomy.model.auto.ProEconPowerFittingAnalySis;
|
|
import com.gyee.runeconomy.model.vo.PointVo;
|
|
import com.gyee.runeconomy.model.vo.PointVo;
|
|
|
|
+import com.gyee.runeconomy.model.vo.PoliceVo;
|
|
|
|
+import com.gyee.runeconomy.model.vo.ResultItem;
|
|
|
|
+import com.gyee.runeconomy.model.vo.alarmWtVo;
|
|
import com.gyee.runeconomy.service.DBSCANPointALG;
|
|
import com.gyee.runeconomy.service.DBSCANPointALG;
|
|
import com.gyee.runeconomy.service.DataScanService;
|
|
import com.gyee.runeconomy.service.DataScanService;
|
|
|
|
+import com.gyee.runeconomy.service.EarlyWarning.ApiClient;
|
|
import com.gyee.runeconomy.service.WindDirection.Point;
|
|
import com.gyee.runeconomy.service.WindDirection.Point;
|
|
import com.gyee.runeconomy.util.FileUtil;
|
|
import com.gyee.runeconomy.util.FileUtil;
|
|
import com.gyee.runeconomy.util.realtimesource.feign.RemoteServiceBuilder;
|
|
import com.gyee.runeconomy.util.realtimesource.feign.RemoteServiceBuilder;
|
|
import com.gyee.runeconomy.util.realtimesource.feign.TsDoubleData;
|
|
import com.gyee.runeconomy.util.realtimesource.feign.TsDoubleData;
|
|
|
|
+import io.swagger.annotations.ApiResponse;
|
|
import lombok.extern.slf4j.Slf4j;
|
|
import lombok.extern.slf4j.Slf4j;
|
|
import lombok.val;
|
|
import lombok.val;
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
@@ -30,8 +40,11 @@ import org.springframework.stereotype.Service;
|
|
|
|
|
|
import javax.annotation.Resource;
|
|
import javax.annotation.Resource;
|
|
import java.io.File;
|
|
import java.io.File;
|
|
|
|
+import java.io.IOException;
|
|
import java.text.DecimalFormat;
|
|
import java.text.DecimalFormat;
|
|
import java.text.SimpleDateFormat;
|
|
import java.text.SimpleDateFormat;
|
|
|
|
+import java.time.LocalDateTime;
|
|
|
|
+import java.time.format.DateTimeFormatter;
|
|
import java.util.*;
|
|
import java.util.*;
|
|
import java.util.concurrent.TimeUnit;
|
|
import java.util.concurrent.TimeUnit;
|
|
import java.util.concurrent.atomic.AtomicReference;
|
|
import java.util.concurrent.atomic.AtomicReference;
|
|
@@ -661,22 +674,167 @@ public class NewDataFittingService {
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
- //
|
|
|
|
- // private boolean deleteDir(String path){
|
|
|
|
- // boolean b =false;
|
|
|
|
- // File directory = new File(path);
|
|
|
|
- // for (File file: Objects.requireNonNull(directory.listFiles())) {
|
|
|
|
- // if (!file.isDirectory()) {
|
|
|
|
- // b = file.delete();
|
|
|
|
- // if(!b){
|
|
|
|
- // return b;
|
|
|
|
- // }
|
|
|
|
- // }
|
|
|
|
- // }
|
|
|
|
- // return b;
|
|
|
|
- //
|
|
|
|
- // }
|
|
|
|
|
|
+ /**
|
|
|
|
+ * @param table // * @param only
|
|
|
|
+ * @return
|
|
|
|
+ */
|
|
|
|
+ public List<AlarmDataVo> getDataAlarms(String table, List<Alarm> alarmList) {
|
|
|
|
+
|
|
|
|
+ ApiClient client = new ApiClient();
|
|
|
|
+
|
|
|
|
+ List<AlarmDataVo> list1 = new ArrayList<>();
|
|
|
|
+ if (table.equals("alarmWt")) {
|
|
|
|
+ for (Alarm alarm : alarmList) {
|
|
|
|
+
|
|
|
|
+ List<ProBasicEquipment> equipments = CacheContext.wtls.stream()
|
|
|
|
+ .filter(a -> alarm.getWtId().equals(a.getAname())).collect(Collectors.toList());
|
|
|
|
+
|
|
|
|
+ String modelId = equipments.get(0).getModelId();
|
|
|
|
+ String wtid = equipments.get(0).getId();
|
|
|
|
+ String station = equipments.get(0).getWindpowerstationId();
|
|
|
|
+ String begin = alarm.getTime();
|
|
|
|
+
|
|
|
|
+ // 定义日期时间格式
|
|
|
|
+ DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");
|
|
|
|
+
|
|
|
|
+ // 将时间字符串转换为 LocalDateTime
|
|
|
|
+ LocalDateTime parsedTime = LocalDateTime.parse(begin, formatter);
|
|
|
|
+
|
|
|
|
+ // 增加一分钟
|
|
|
|
+// LocalDateTime endTime = parsedTime.plusMinutes(1);
|
|
|
|
+ LocalDateTime endTime = parsedTime.plusDays(1);
|
|
|
|
+
|
|
|
|
+ // 将新的时间转换回字符串
|
|
|
|
+ String end = endTime.format(formatter);
|
|
|
|
+
|
|
|
|
+ String result = client.getglqxgzFromApi(
|
|
|
|
+ station,
|
|
|
|
+ wtid,
|
|
|
|
+ modelId,
|
|
|
|
+ "",
|
|
|
|
+ begin,
|
|
|
|
+ end,
|
|
|
|
+ "1",
|
|
|
|
+ "20",
|
|
|
|
+ "gz"
|
|
|
|
+ );
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+ String json = result;
|
|
|
|
+
|
|
|
|
+ ObjectMapper mapper = new ObjectMapper();
|
|
|
|
+ try {
|
|
|
|
+ alarmWtVo response = mapper.readValue(json, alarmWtVo.class);
|
|
|
|
+
|
|
|
|
+ // 使用解析后的数据
|
|
|
|
+ for (ResultItem item : response.getData().getResult()) {
|
|
|
|
+ // 读取所需数据
|
|
|
|
+ AlarmDataVo vo = new AlarmDataVo();
|
|
|
|
+ vo.setWtid(equipments.get(0).getAname());
|
|
|
|
+ vo.setTime(begin);
|
|
|
|
+ vo.setBj("故障");
|
|
|
|
+ vo.setTx("自定义");
|
|
|
|
+ vo.setAlarmname(item.getFaultView());
|
|
|
|
+ list1.add(vo);
|
|
|
|
+ }
|
|
|
|
+ } catch (Exception e) {
|
|
|
|
+ e.printStackTrace();
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ }
|
|
|
|
|
|
|
|
+ return list1;
|
|
|
|
+
|
|
|
|
+ } else if (table.equals("alarmCt")) {
|
|
|
|
+
|
|
|
|
+ for (Alarm alarm : alarmList) {
|
|
|
|
+
|
|
|
|
+ List<ProBasicEquipment> equipments = CacheContext.wtls.stream()
|
|
|
|
+ .filter(a -> alarm.getWtId().equals(a.getAname())).collect(Collectors.toList());
|
|
|
|
+
|
|
|
|
+ String modelId = equipments.get(0).getModelId();
|
|
|
|
+ String wtid = equipments.get(0).getId();
|
|
|
|
+ String begin = alarm.getTime();
|
|
|
|
+
|
|
|
|
+ // 定义日期时间格式
|
|
|
|
+ DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");
|
|
|
|
+
|
|
|
|
+ // 将时间字符串转换为 LocalDateTime
|
|
|
|
+ LocalDateTime parsedTime = LocalDateTime.parse(begin, formatter);
|
|
|
|
+
|
|
|
|
+ // 增加一分钟
|
|
|
|
+ LocalDateTime endTime = parsedTime.plusMinutes(1);
|
|
|
|
+
|
|
|
|
+ // 将新的时间转换回字符串
|
|
|
|
+ String end = endTime.format(formatter);
|
|
|
|
+
|
|
|
|
+ String result = client.getDataFromApi(
|
|
|
|
+ begin,
|
|
|
|
+ end,
|
|
|
|
+ wtid,
|
|
|
|
+ modelId,
|
|
|
|
+ "windturbine",
|
|
|
|
+ "", // 如果没有 alarmIds,可以传空字符串
|
|
|
|
+ "s"
|
|
|
|
+ );
|
|
|
|
+
|
|
|
|
+// String result = "[\n" +
|
|
|
|
+// " {\n" +
|
|
|
|
+// " \"GJNY_SXGS_LJSF01_LN\":[\n" +
|
|
|
|
+// " {\n" +
|
|
|
|
+// " \"snapId\":1302951473243889700,\n" +
|
|
|
|
+// " \"stationId\":\"GJNY_SXGS_LJSF01_LN\",\n" +
|
|
|
|
+// " \"windturbineId\":null,\n" +
|
|
|
|
+// " \"alertText\":\"变桨电容电压小于57v\",\n" +
|
|
|
|
+// " \"count\":1,\n" +
|
|
|
|
+// " \"alarmid\":\"0000425\",\n" +
|
|
|
|
+// " \"time\":0,\n" +
|
|
|
|
+// " \"relateParts\":\"BJXT\",\n" +
|
|
|
|
+// " \"relatePartsText\":\"变桨系统\",\n" +
|
|
|
|
+// " \"code\":null,\n" +
|
|
|
|
+// " \"windturbineCode\":null,\n" +
|
|
|
|
+// " \"lineId\":null\n" +
|
|
|
|
+// " },\n" +
|
|
|
|
+// " {\n" +
|
|
|
|
+// " \"snapId\":1302951473243889700,\n" +
|
|
|
|
+// " \"stationId\":\"GJNY_SXGS_LJSF01_LN\",\n" +
|
|
|
|
+// " \"windturbineId\":null,\n" +
|
|
|
|
+// " \"alertText\":\"如果风机轴a 和 轴b 温度差 大于20度,则报警\",\n" +
|
|
|
|
+// " \"count\":3,\n" +
|
|
|
|
+// " \"alarmid\":\"0000454\",\n" +
|
|
|
|
+// " \"time\":4270,\n" +
|
|
|
|
+// " \"relateParts\":\"ZZ\",\n" +
|
|
|
|
+// " \"relatePartsText\":null,\n" +
|
|
|
|
+// " \"code\":null,\n" +
|
|
|
|
+// " \"windturbineCode\":null,\n" +
|
|
|
|
+// " \"lineId\":null\n" +
|
|
|
|
+// " }\n" +
|
|
|
|
+// " ]\n" +
|
|
|
|
+// " }\n" +
|
|
|
|
+// "]";
|
|
|
|
+ List response = AlarmDataParser.parseResponse(result);
|
|
|
|
+
|
|
|
|
+ if (response != null) {
|
|
|
|
+ for (Object resc : response) {
|
|
|
|
+ AlarmDataParser.AlarmData alarmData = (AlarmDataParser.AlarmData) resc;
|
|
|
|
+ // 读取所需数据
|
|
|
|
+ String alertText = alarmData.getAlertText(); // 预警内容
|
|
|
|
+ String relateType = alarmData.getRelatePartsText(); // 部件名称
|
|
|
|
+ AlarmDataVo vo = new AlarmDataVo();
|
|
|
|
+ vo.setWtid(equipments.get(0).getAname());
|
|
|
|
+ vo.setTime(begin);
|
|
|
|
+ vo.setBj(relateType);
|
|
|
|
+ vo.setTx("自定义");
|
|
|
|
+ vo.setAlarmname(alertText);
|
|
|
|
+ list1.add(vo);
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ return list1;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ return list1;
|
|
|
|
+ }
|
|
|
|
|
|
}
|
|
}
|
|
|
|
|