liulingling.177216
2024-08-26 349f1cfc5fa77fbc636d542df0d8050fddec48c2
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
package com.dingzhuo.energy.project.energyStatistics.controller;
 
import com.dingzhuo.energy.common.utils.poi.ExcelUtil;
import com.dingzhuo.energy.data.model.domain.EnergyIndex;
import com.dingzhuo.energy.data.model.service.IModelNodeService;
import com.dingzhuo.energy.dataservice.domain.DataItem;
import com.dingzhuo.energy.dataservice.service.PeriodDataService;
import com.dingzhuo.energy.framework.aspectj.lang.annotation.Log;
import com.dingzhuo.energy.framework.aspectj.lang.enums.BusinessType;
import com.dingzhuo.energy.framework.web.controller.BaseController;
import com.dingzhuo.energy.framework.web.domain.AjaxResult;
import com.dingzhuo.energy.project.energyStatistics.domain.energyAnalysis;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
 
import java.math.BigDecimal;
import java.util.*;
import java.util.concurrent.atomic.AtomicInteger;
import java.util.stream.Collectors;
 
/**
 * electricityPriceController
 *
 * @author sys
 * @date 2020-02-18
 */
@RestController
@RequestMapping("/energyAnalysis")
public class energyAnalysisController extends BaseController {
 
    @Autowired
    private PeriodDataService periodDataService;
    @Autowired
    private IModelNodeService modelNodeService;
    @Autowired
    private com.dingzhuo.energy.project.energyStatistics.service.IEnergyStatisticsService IEnergyStatisticsService;
 
    @GetMapping("/getEnergyAnalysis")
    public AjaxResult getEnergyAnalysis(DataItem dataItem) {
        try {
            List<EnergyIndex> list = modelNodeService.getSettingIndex(dataItem.getIndexCode());
            List<String> indexCode = list.stream().map(EnergyIndex::getIndexId).collect(Collectors.toList());
            List<DataItem> result = periodDataService.getDatasByIndex(indexCode, dataItem.getBeginTime(), dataItem.getEndTime(), dataItem.getTimeType());
            Map<String, List<DataItem>> groupBy = result.stream().collect(Collectors.groupingBy(DataItem::getIndexCode));
            energyAnalysis tableData =new energyAnalysis();
            List<energyAnalysis> tableDataMaps = new ArrayList<>();
            List<Map> energyHeadList = new ArrayList<Map>();
            AtomicInteger colcount= new AtomicInteger(1);//表格列的数量
            /*groupBy.forEach((IndexName,value)->{
                Map tableColumn =new HashMap<>();//表数据
                Map table =new HashMap<>();//表数据
                for(DataItem re:value){
                    energyAnalysis energyHead = new energyAnalysis();
                    energyHead.setDataTime(re.getDataTime());
                    energyHead.setValue(re.getValue());
                    energyHead.setProp("col"+ colcount);
                    tableDataMaps.add(energyHead);
                }
                colcount.getAndIncrement();
                tableColumn.put("IndexName",IndexName);
                tableColumn.put("prop",IndexName);
                energyHeadList.add(tableColumn);
                tableData.setAnalysisTableHead(energyHeadList);
                tableData.setAnalysisTableDate(tableDataMaps);
            });*/
            return AjaxResult.success(result);
        } catch (Exception ex) {
            logger.error("获取出错!", ex);
            return AjaxResult.error("获取出错!");
        }
    }
    @Log(title = "能耗统计分析", businessType = BusinessType.EXPORT)
    @GetMapping("/export")
    public AjaxResult export(DataItem dataItem) { {
        List<EnergyIndex> indexCodeList = modelNodeService.getSettingIndex(dataItem.getIndexCode());
        List<String> indexCode = indexCodeList.stream().map(EnergyIndex::getIndexId).collect(Collectors.toList());
        List<DataItem> list = periodDataService.getDatasByIndex(indexCode, dataItem.getBeginTime(), dataItem.getEndTime(), dataItem.getTimeType());
        ExcelUtil<DataItem> util = new ExcelUtil<DataItem>(DataItem.class);
        return util.exportExcel(list, "exportEnergyAnalysis");
    }
}}