From 64f046ed41c2ae607dc065c82b6d454f64e90584 Mon Sep 17 00:00:00 2001 From: whyclxw <810412026@qq.com> Date: 星期四, 19 六月 2025 21:52:33 +0800 Subject: [PATCH] 预警分析管理-电源告警 --- src/main/java/com/whyc/service/PwrdevHistorydataIdService.java | 24 ++++++++++++++++++------ 1 files changed, 18 insertions(+), 6 deletions(-) diff --git a/src/main/java/com/whyc/service/PwrdevHistorydataIdService.java b/src/main/java/com/whyc/service/PwrdevHistorydataIdService.java index 2c3e675..77e9231 100644 --- a/src/main/java/com/whyc/service/PwrdevHistorydataIdService.java +++ b/src/main/java/com/whyc/service/PwrdevHistorydataIdService.java @@ -20,6 +20,7 @@ import org.springframework.stereotype.Service; import javax.annotation.Resource; +import java.lang.reflect.Field; import java.time.LocalDateTime; import java.time.format.DateTimeFormatter; import java.util.Date; @@ -90,7 +91,7 @@ return new Response().setIII(1,datalist.size()>0,datalist,modelCfg,"鑾峰彇鍗婂皬鏃跺唴鐩存祦杈撳嚭缁熻"); } //1.2.7浼樿壇鐢垫簮缁熻涓婁竴瀛e害鐨勭數婧愭煇涓�灞炴�у拰鍙傛暟闃堝�艰秴杩囩殑娆℃暟 - public Integer getPwrQuarter7(Integer powerId,Integer powerType) { + public Integer getPwrQuarter7(Integer powerId,Integer powerType) throws NoSuchFieldException, IllegalAccessException { Map<String,Integer> map=new HashMap<>(); //鑾峰彇浼樿壇鐢垫簮鎬ц兘缁熻鍦ㄥ钩鍙颁笂鐨勬椂闂村弬鏁拌缃〃 ApptimeParam apptimeParam=apptimeParamService.getPwrPerformanceStrartTime(powerId); @@ -98,12 +99,12 @@ List<String> datelist=ActionUtil.getDateListBetweenDates(apptimeParam.getParamValue(), new Date()); //鑾峰彇鐢垫簮浼樿壇鍒ゆ柇鐨勬爣鍑嗗弬鏁板�� List<PowerPropertyParam> paramList=propertyParamService.getPwrStandardParam(powerType); - Map<String,Float> paramValues=new HashMap<>(); + /*Map<String,Float> paramValues=new HashMap<>(); for (PowerPropertyParam param : paramList) { paramValues.put(param.getPropertyName()+"_upper", param.getBasisVal()*param.getAlarmLimithUpper()); paramValues.put(param.getPropertyName()+"_lower", param.getBasisVal()*param.getAlarmLimitlLower()); map.put(param.getPropertyName(), 0); - } + }*/ for (int i=0;i<datelist.size();i++) { String date=datelist.get(i); String tableName ="db_data_history.tb_pwrdev_historydata_"+powerId+"_"+date; @@ -112,10 +113,10 @@ if(existTableName == null){ continue; } - List<QuarterPwr7Res> datalist=subTablePageInfoService.getPwrQuarter7(tableName); + List<PwrdevHistorydataId> datalist=subTablePageInfoService.getPwrQuarter7(tableName); // 閬嶅巻 dataList 骞舵瘮杈冨睘鎬у�� - for (QuarterPwr7Res data : datalist) { - if(paramValues.get("acin1_vola_upper")!=null){ + for (PwrdevHistorydataId data : datalist) { + /*if(paramValues.get("acin1_vola_upper")!=null){ if ((data.getAcin1Vola() > paramValues.get("acin1_vola_upper"))||(data.getAcin1Vola() < paramValues.get("acin1_vola_lower"))) { map.put("acin1_vola", map.get("acin1_vola") + 1); } @@ -134,6 +135,17 @@ if ((data.getDcoutCurr() > paramValues.get("dcout_curr_upper")) || (data.getDcoutCurr() < paramValues.get("dcout_curr_lower"))) { map.put("dcout_curr", map.get("dcout_curr") + 1); } + }*/ + for (int j=0;j<paramList.size();j++) { + PowerPropertyParam param = paramList.get(j); + String propertyName = ActionUtil.toCamelCase(param.getPropertyName()); + Field field = PwrdevHistorydataId.class.getDeclaredField(propertyName); + field.setAccessible(true); // 濡傛灉瀛楁鏄鏈夌殑锛岄渶瑕佽缃负鍙闂� + Float value = (Float) field.get(data); + if ((value > (param.getBasisVal()*param.getAlarmLimithUpper()))||(value <(param.getBasisVal()*param.getAlarmLimitlLower()))) { + int limitNum=map.get(param.getPropertyName())==null?0:map.get(param.getPropertyName()); + map.put(param.getPropertyName(), limitNum+1); + } } } } -- Gitblit v1.9.1