|
@@ -1,5 +1,6 @@
|
|
|
package com.gyee.runeconomy.service.Electricity;
|
|
|
|
|
|
+import com.gyee.common.contant.ContantXk;
|
|
|
import com.gyee.common.util.DateUtils;
|
|
|
import com.gyee.common.util.SortUtils;
|
|
|
import com.gyee.runeconomy.dto.CoulometricVo;
|
|
@@ -82,8 +83,8 @@ public class Electricityservice {
|
|
|
int day = 0;
|
|
|
|
|
|
// // 当前年份
|
|
|
-// Calendar cal = Calendar.getInstance();
|
|
|
-// int currentyear = cal.get(Calendar.YEAR);
|
|
|
+ Calendar cal = Calendar.getInstance();
|
|
|
+ int dqnf = cal.get(Calendar.YEAR);
|
|
|
int currentyear = Integer.parseInt(year);
|
|
|
|
|
|
// 当月第一天0点值
|
|
@@ -113,11 +114,20 @@ public class Electricityservice {
|
|
|
|
|
|
Date firstDayZeroHour = calendar2.getTime();
|
|
|
|
|
|
+ // 获取firstDayZeroHour的月份
|
|
|
+ Calendar calFirstDayZeroHour = Calendar.getInstance();
|
|
|
+ calFirstDayZeroHour.setTime(firstDayZeroHour);
|
|
|
+ int calFirstMonth = calFirstDayZeroHour.get(Calendar.MONTH) + 1;
|
|
|
+ //当前时间月份
|
|
|
+ Calendar calendar7 = Calendar.getInstance();
|
|
|
+ int currentMonth = calendar7.get(Calendar.MONTH);
|
|
|
+ currentMonth = currentMonth + 1;
|
|
|
|
|
|
for (int i = 1; i <= 12; i++) {
|
|
|
double bnjhdlsum = 0.0;
|
|
|
double yeardlsum = 0.0;
|
|
|
double bysjdlhjsum = 0.0;
|
|
|
+ double rfdlsj = 0.0;
|
|
|
BigDecimal dqzqlsum = null;
|
|
|
BigDecimal rfdlyclsum = null;
|
|
|
day = i;
|
|
@@ -136,6 +146,8 @@ public class Electricityservice {
|
|
|
List<ProBasicProjectPlan> currentjh = currentls.stream().filter(wp -> wp.getWindpowerstationId().equals(wpls.getId())).collect(Collectors.toList());
|
|
|
bnjhdlsum += currentjh.stream().mapToDouble(ProBasicProjectPlan::getGeneratingCapacity).sum(); //本月计划电量合
|
|
|
|
|
|
+ ProBasicPowerstationPoint rfdlvalue = proBasicPowerstationPointService.getPowerstationPoint(wpls.getId(), ContantXk.RFDL);
|
|
|
+ rfdlsj = edosUtil.getRealData(rfdlvalue).getPointValueInDouble();
|
|
|
|
|
|
//实际电量
|
|
|
List<ProEconPowerstationInfoDay5> sjdlls = proEconPowerstationInfoDay5Service.getmax(wpls.getId(), firstDayZeroHour);
|
|
@@ -171,7 +183,11 @@ public class Electricityservice {
|
|
|
// //添加实际电量
|
|
|
// PointData data = edosUtil.getSectionData(month, endOfDayOfLastDayOfMonth.getTime());
|
|
|
// PointData data = edosUtil.getSectionData(month, date1.getTime());
|
|
|
- vo.setSjdl(StringUtils.round(bysjdlhjsum / 10000, 2));
|
|
|
+ if (calFirstMonth == currentMonth && currentyear == dqnf) {
|
|
|
+ vo.setSjdl(StringUtils.round((bysjdlhjsum / 10000) + (rfdlsj /10000), 2));
|
|
|
+ } else {
|
|
|
+ vo.setSjdl(StringUtils.round(bysjdlhjsum / 10000, 2));
|
|
|
+ }
|
|
|
|
|
|
|
|
|
//添加当月占比
|
|
@@ -195,6 +211,9 @@ public class Electricityservice {
|
|
|
|
|
|
firstDayZeroHour = DateUtils.addMonths(firstDayZeroHour, +1);
|
|
|
|
|
|
+ calFirstDayZeroHour.setTime(firstDayZeroHour);
|
|
|
+ calFirstMonth = calFirstDayZeroHour.get(Calendar.MONTH) + 1;
|
|
|
+
|
|
|
vos.add(vo);
|
|
|
SortUtils.sort(vos, "hours", SortUtils.ASC);
|
|
|
map.put("value", vos);
|
|
@@ -202,6 +221,7 @@ public class Electricityservice {
|
|
|
|
|
|
double yeardlsum = 0.0;
|
|
|
double bnsjdlhjsum = 0.0;
|
|
|
+ double rfdlsjhj = 0.0;
|
|
|
BigDecimal dqzqlhjsum = null;
|
|
|
BigDecimal rfdlychjsum = null;
|
|
|
|
|
@@ -217,6 +237,10 @@ public class Electricityservice {
|
|
|
// PointData bnsjdlhj = edosUtil.getHistMatrix(nfdl, currentDate.getTime() / 1000);
|
|
|
// bnsjdlhjsum += bnsjdlhj.getPointValueInDouble();
|
|
|
|
|
|
+ ProBasicPowerstationPoint rfdlvalue = proBasicPowerstationPointService.getPowerstationPoint(wpls.getId(), ContantXk.RFDL);
|
|
|
+ rfdlsjhj = edosUtil.getRealData(rfdlvalue).getPointValueInDouble();
|
|
|
+
|
|
|
+
|
|
|
List<ProEconPowerstationInfoDay5> sjdlls = proEconPowerstationInfoDay5Service.getmax(wpls.getId(), yearHour);
|
|
|
if (!sjdlls.isEmpty() && sjdlls != null) {
|
|
|
bnsjdlhjsum += sjdlls.get(0).getNfdldb().doubleValue();
|
|
@@ -239,7 +263,7 @@ public class Electricityservice {
|
|
|
}
|
|
|
map.put("bnjhdlhj", MathUtil.twoBit(yeardlsum));
|
|
|
map.put("rfdlychj", rfdlychjsum);
|
|
|
- map.put("bnsjdlhj", MathUtil.twoBit(bnsjdlhjsum / 10000));
|
|
|
+ map.put("bnsjdlhj", MathUtil.twoBit((bnsjdlhjsum / 10000) + (rfdlsjhj / 10000)));
|
|
|
if (yeardlsum!=0) {
|
|
|
map.put("qnzbhj", StringUtils.round(((bnsjdlhjsum / 10000) / yeardlsum) * 100, 0));
|
|
|
} else {
|
|
@@ -316,6 +340,8 @@ public class Electricityservice {
|
|
|
|
|
|
double bnsjdlhjsum = 0.0;
|
|
|
|
|
|
+ double rfdlsjhj = 0.0;
|
|
|
+
|
|
|
double bnrzqdhjsum = 0.0;
|
|
|
|
|
|
double dxxsssum = 0.0;
|
|
@@ -333,6 +359,8 @@ public class Electricityservice {
|
|
|
//本月可研电量合计
|
|
|
double bykydlhjsum = 0.0;
|
|
|
|
|
|
+ double rfdlsj = 0.0;
|
|
|
+
|
|
|
if (calFirstMonth == currentMonth && dqnf==currentyear) {
|
|
|
Calendar calendar5 = Calendar.getInstance();
|
|
|
ts = calendar5.get(Calendar.DAY_OF_MONTH);
|
|
@@ -358,6 +386,8 @@ public class Electricityservice {
|
|
|
List<ProBasicFeasibilityStudy> currentky = currentkyls.stream().filter(wp -> wp.getWindpowerstationId().equals(wpls.getId())).collect(Collectors.toList());
|
|
|
bykydlhjsum = currentky.stream().mapToDouble(ProBasicFeasibilityStudy::getGeneratingCapacity).sum(); //本月可研电量合
|
|
|
|
|
|
+ ProBasicPowerstationPoint rfdlvalue = proBasicPowerstationPointService.getPowerstationPoint(wpls.getId(), ContantXk.RFDL);
|
|
|
+ rfdlsj = edosUtil.getRealData(rfdlvalue).getPointValueInDouble();
|
|
|
//当前场站循环月实际电量
|
|
|
List<ProEconPowerstationInfoDay5> sjdlls = proEconPowerstationInfoDay5Service.getmax(wpls.getId(), firstDayZeroHour);
|
|
|
if (!sjdlls.isEmpty() && sjdlls != null) {
|
|
@@ -381,7 +411,11 @@ public class Electricityservice {
|
|
|
vo.setJhdl(StringUtils.round(byjhdlsum, 2));
|
|
|
vo.setHours(i);
|
|
|
//添加实际电量
|
|
|
- vo.setSjdl(StringUtils.round(bysjdlhjsum / 10000, 2));
|
|
|
+ if (calFirstMonth == currentMonth && dqnf==currentyear) {
|
|
|
+ vo.setSjdl(StringUtils.round((bysjdlhjsum / 10000) + (rfdlsj / 10000), 2));
|
|
|
+ } else {
|
|
|
+ vo.setSjdl(StringUtils.round(bysjdlhjsum / 10000, 2));
|
|
|
+ }
|
|
|
vo.setKydl(StringUtils.round(bykydlhjsum,2));
|
|
|
//添加完成情况
|
|
|
if (byjhdlsum != 0) {
|
|
@@ -421,6 +455,9 @@ public class Electricityservice {
|
|
|
yeardlsum = yearjh.stream().mapToDouble(ProBasicProjectPlan::getGeneratingCapacity).sum();
|
|
|
kyyeardlsum = kyyearjh.stream().mapToDouble(ProBasicFeasibilityStudy::getGeneratingCapacity).sum();
|
|
|
|
|
|
+ ProBasicPowerstationPoint rfdlvalue = proBasicPowerstationPointService.getPowerstationPoint(wpId, ContantXk.RFDL);
|
|
|
+ rfdlsjhj = edosUtil.getRealData(rfdlvalue).getPointValueInDouble();
|
|
|
+
|
|
|
List<ProEconPowerstationInfoDay5> sjdlls = proEconPowerstationInfoDay5Service.getmax(wpId, yearHour);
|
|
|
if (!sjdlls.isEmpty() && sjdlls != null) {
|
|
|
bnsjdlhjsum += sjdlls.get(0).getNfdldb().doubleValue();
|
|
@@ -433,7 +470,7 @@ public class Electricityservice {
|
|
|
|
|
|
map.put("jhdlhj",yeardlsum);
|
|
|
map.put("kydlhj",kyyeardlsum);
|
|
|
- map.put("sjdlhj",StringUtils.round((bnsjdlhjsum / 10000),2));
|
|
|
+ map.put("sjdlhj",StringUtils.round(((bnsjdlhjsum / 10000)) + (rfdlsjhj / 10000),2));
|
|
|
if (yeardlsum != 0) {
|
|
|
map.put("wcqkhj", StringUtils.round(((bnsjdlhjsum / 10000) / yeardlsum) * 100, 0));
|
|
|
}else {
|