YYC
2023-11-02 9005fab8f1ef7b68557a670169331a17e74187d2
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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
package com.ld.igds.grain.manager;
 
import com.ld.igds.constant.DepotType;
import com.ld.igds.grain.*;
import com.ld.igds.grain.dto.*;
import com.ld.igds.models.Depot;
import com.ld.igds.util.ContextUtil;
import com.ld.igds.util.FilesUtil;
import com.ld.igds.util.NumberUtil;
import lombok.extern.slf4j.Slf4j;
import org.apache.commons.lang3.StringUtils;
import org.apache.commons.lang3.time.DateFormatUtils;
import org.apache.poi.hssf.usermodel.*;
import org.apache.poi.ss.usermodel.*;
import org.apache.poi.ss.util.CellRangeAddress;
import org.springframework.stereotype.Component;
 
import javax.annotation.Resource;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
 
 
/**
 * @Desc: 粮情页面批量导出EXCEL
 * @author: Andy
 * @update-time: 2022/12/8
 */
@Slf4j
@Component
public class GrainExportBuilder {
 
 
    @Resource
    private FilesUtil filesUtil;
 
    /**
     * 生成生成
     *
     * @param dataMap
     * @return 如果返回信息以:ERROR:开头表示执行出错,正常返回文件名称
     */
    public String exportByMapData(Map<String, GrainData> dataMap, List<Depot> listDepot) {
 
        String result;
        try {
            //创建一个新的EXCEL
            HSSFWorkbook toWorkbook = createWorkBook();
            HSSFWorkbook fromWorkBook;
 
            Map<String, HSSFWorkbook> mapWorkBook = new HashMap<>();
 
            HSSFSheet newSheet, oldSheet;
 
            Depot depot = null;
            String cableKey = "";
            for (GrainData data : dataMap.values()) {
                depot = this.getDepot(data.getDepotId(), listDepot);
 
                if (null == depot) {
                    log.info("--------粮情导出EXCEL没有获取到仓库信息,取消导出----{}", data.getDepotId());
                    continue;
                }
                if (StringUtils.isEmpty(data.getCableCir())) {
                    cableKey = data.getCable();
                } else {
                    cableKey = data.getCable() + "_" + data.getCableCir();
                }
 
                fromWorkBook = mapWorkBook.get(cableKey);
                if (null == fromWorkBook) {
                    fromWorkBook = this.getFromWorkBook(data, depot);
                    mapWorkBook.put(cableKey, fromWorkBook);
                }
 
                newSheet = toWorkbook.createSheet(depot.getName());
 
                oldSheet = fromWorkBook.getSheetAt(0);
 
                this.copySheet(newSheet, oldSheet, toWorkbook, data, depot);
 
                Thread.sleep(300);
            }
 
            result = ContextUtil.getTimeId() + ".xls";
            String tempPath = filesUtil.getTempPath(depot == null ? ContextUtil.getDefaultCompanyId() : depot.getCompanyId());
            FileOutputStream fos = new FileOutputStream(tempPath + "/" + result);
            toWorkbook.write(fos);
            if (null != fos) fos.close();
 
        } catch (Exception e) {
            log.info("---------------导出异常信息----{}", e);
            result = "ERROR:导出错误:" + e.getMessage();
        }
 
        return result;
    }
 
    private HSSFWorkbook getFromWorkBook(GrainData data, Depot depot) throws Exception {
        FileInputStream fis = null;
 
        String filePath = filesUtil.getConfPath();
        try {
            //获取模版的名称,注意筒仓名称配置规则
            if (StringUtils.isEmpty(data.getCableCir())) {
                filePath = filePath + "/" + data.getCable() + ".xls";
            } else {
                filePath = filePath + "/" + data.getCable() + "_" + data.getCableCir() + ".xls";
            }
 
            fis = new FileInputStream(filePath);
            HSSFWorkbook wb = new HSSFWorkbook(fis);
 
            return wb;
        } catch (Exception e) {
            log.error("------根据粮情导出EXCEL执行异常:{}", e);
            return null;
        } finally {
            if (null != fis) fis.close();
        }
    }
 
    private Depot getDepot(String depotId, List<Depot> listDepot) {
        if (listDepot == null || listDepot.isEmpty()) return null;
 
        for (Depot depot : listDepot) {
            if (depot.getId().equals(depotId)) return depot;
        }
        return null;
    }
 
 
    private HSSFWorkbook createWorkBook() {
        return new HSSFWorkbook();
    }
 
 
    /**
     * 复制sheet
     *
     * @param newSheet
     * @param oldSheet
     * @return
     */
    public Sheet copySheet(HSSFSheet newSheet, HSSFSheet oldSheet, Workbook workbook, GrainData data, Depot depot) {
 
        //合并单元格
        int numMergedRegions = oldSheet.getNumMergedRegions();
        for (int i = 0; i < numMergedRegions; i++) {
            CellRangeAddress mergedRegion = oldSheet.getMergedRegion(i);
            newSheet.addMergedRegion(mergedRegion);
        }
 
 
        // 设置列宽
        int physicalNumberOfCells = oldSheet.getRow(0).getPhysicalNumberOfCells();
        for (int i = 0; i < physicalNumberOfCells; i++) {
            HSSFRow fromRow = oldSheet.getRow(i);
            if (null == fromRow) continue;
            for (int j = fromRow.getLastCellNum(); j >= fromRow.getFirstCellNum(); j--) {
                newSheet.setColumnWidth(j, oldSheet.getColumnWidth(j));
                newSheet.setColumnHidden(j, false);
            }
        }
 
 
        //此处需要将 cellStyle 定义在遍历行的地方,定义在外面可能出现样式渲染错误
        CellStyle cellStyle = workbook.createCellStyle();
        cellStyle.setBorderBottom(CellStyle.BORDER_THIN);
        cellStyle.setBorderLeft(CellStyle.BORDER_THIN);
        cellStyle.setBorderRight(CellStyle.BORDER_THIN);
        cellStyle.setBorderTop(CellStyle.BORDER_THIN);
        cellStyle.setAlignment(CellStyle.ALIGN_CENTER);
        cellStyle.setVerticalAlignment(CellStyle.VERTICAL_CENTER);
        cellStyle.setWrapText(true);
 
 
        //每次完成一个删除一个
        List<GrainPoint> listPoints = data.getListPoints();
 
        //最大获取行数
        int maxRowSize = oldSheet.getPhysicalNumberOfRows() - 1;
        for (int i = 0; i < maxRowSize; i++) {
            Row newRow = newSheet.createRow(i);
            Row oldRow = oldSheet.getRow(i);
            newRow.setHeight((short) (20 * 20));
 
            int maxColSize = oldRow.getPhysicalNumberOfCells();
 
            String oldCellValue;
            for (int j = 0; j < maxColSize; j++) {
                Cell newCell = newRow.createCell(j);
                Cell oldCell = oldRow.getCell(j);
                if (oldCell == null) {
                    continue;
                }
                oldCellValue = oldCell.getStringCellValue();
 
                newCell.setCellValue(getNewCellValue(oldCellValue, listPoints, data, depot));
 
                newCell.setCellStyle(cellStyle);
            }
        }
        return newSheet;
    }
 
 
    /**
     * 根据单元格标签替换值,需要替换的标记为c_
     *
     * @param oldCellValue
     * @param data
     * @return
     */
    public String getNewCellValue(String oldCellValue, List<GrainPoint> listPoints, GrainData data, Depot depot) {
 
        try {
 
            if (null == oldCellValue) return null;
 
            if (!oldCellValue.startsWith("c_")) return oldCellValue;
 
            if ("c_title".equals(oldCellValue)) return "粮情报表";
            if ("c_depot".equals(oldCellValue)) return depot.getName() + "粮情报表";
            if ("c_weather".equals(oldCellValue)) return data.getWeather();
            if ("c_checkDate".equals(oldCellValue))
                return DateFormatUtils.format(data.getReceiveDate(), "yyyy-MM-dd HH:mm");
            if ("c_ori".equals(oldCellValue)) return "";
            if ("c_tIn".equals(oldCellValue)) return getStrValue(data.getTempIn());
            if ("c_tOut".equals(oldCellValue)) return getStrValue(data.getTempOut());
            if ("c_hIn".equals(oldCellValue)) return getStrValue(data.getHumidityIn());
            if ("c_hOut".equals(oldCellValue)) return getStrValue(data.getHumidityOut());
 
            if ("c_tempMax".equals(oldCellValue)) return getStrValue(data.getTempMax());
            if ("c_tempMin".equals(oldCellValue)) return getStrValue(data.getTempMin());
            if ("c_tempAve".equals(oldCellValue)) return getStrValue(data.getTempAve());
            if ("c_depotType".equals(oldCellValue)) return depot.getDepotTypeName();
            if ("c_storeDate".equals(oldCellValue))
                return null == depot.getStoreDate() ? null : DateFormatUtils.format(depot.getStoreDate(), "yyyy-MM-dd");
            if ("c_foodVariety".equals(oldCellValue)) return depot.getFoodVarietyName();
            if ("c_storageReal".equals(oldCellValue)) return getStrValue(NumberUtil.keepPrecision(depot.getStorageReal()/1000, 2));
            if ("c_foodLocation".equals(oldCellValue)) return depot.getFoodLocation();
            if ("c_bulkWeight".equals(oldCellValue)) return getStrValue(depot.getBulkWeight());
            if ("c_checkUser".equals(oldCellValue)) return data.getCheckUser();
            if ("c_storeKeeper".equals(oldCellValue)) return depot.getStoreKeeperName();
            if ("c_createDate".equals(oldCellValue)) return DateFormatUtils.format(new Date(), "yyyy-MM-dd HH:mm");
 
            if (oldCellValue.startsWith("c_lay_")) {
                String[] tempAttr = oldCellValue.split("_");
                int layNum = Integer.valueOf(tempAttr[3]);
                for (GrainLay lay : data.getListLays()) {
                    if (lay.getFz() == layNum) {
                        if (oldCellValue.indexOf("max") > 0) return getStrValue(lay.getTempMax());
                        if (oldCellValue.indexOf("min") > 0) return getStrValue(lay.getTempMin());
                        if (oldCellValue.indexOf("ave") > 0) return getStrValue(lay.getTempAve());
                    }
                }
                return oldCellValue;
            }
 
 
            //平房仓的获取方式
 
            if (DepotType.TYPE_01.getCode().equals(depot.getDepotType())) {
                return getNewCellValue01(data, oldCellValue, listPoints);
            }
 
            if (DepotType.TYPE_02.getCode().equals(depot.getDepotType())) {
                return getNewCellValue02(data, oldCellValue, listPoints);
            }
 
            if (DepotType.TYPE_03.getCode().equals(depot.getDepotType())) {
                return getNewCellValue02(data, oldCellValue, listPoints);
            }
 
            if (DepotType.TYPE_04.getCode().equals(depot.getDepotType())) {
                return getNewCellValue02(data, oldCellValue, listPoints);
            }
 
        } catch (Exception e) {
            log.error("---------批量导出粮情EXCEL---赋值出错---{}", e);
            return oldCellValue;
        }
 
        return null;
    }
 
 
    /**
     * @Desc: 筒仓的粮温点规则c_x_y_z 其中x = 表示圈数,y=总根数,z= 当前层
     * @author: Andy
     * @update-time: 2022/12/12
     */
    private String getNewCellValue02(GrainData data, String oldCellValue, List<GrainPoint> listPoints) {
        //单元格赋值 c_x_y_z 其中x = 表示圈数,y=总根数,z= 当前层
        String[] attr = oldCellValue.split("_");
        int x = Integer.valueOf(attr[1]), y = Integer.valueOf(attr[2]), z = Integer.valueOf(attr[3]);
 
        x = x - 1;
        y = y - 1;
        GrainPoint point;
        for (int i = 0; i < listPoints.size(); i++) {
            point = listPoints.get(i);
 
            if (point.getX() == x && point.getY() == y && point.getFz() == z) {
                listPoints.remove(i);
                return GrainDataBuilder.renderTempValue(point.getTemp());
            }
        }
 
        return "--";
    }
 
 
    private String getNewCellValue01(GrainData data, String oldCellValue, List<GrainPoint> listPoints) {
        String cable = data.getCable();
        String[] attrCable = cable.split("-");
        int numX = Integer.valueOf(attrCable[2]);
 
 
        //单元格赋值 c_层_行_列
        String[] attr = oldCellValue.split("_");
        int lay = Integer.valueOf(attr[1]), row = Integer.valueOf(attr[2]), col = Integer.valueOf(attr[3]);
 
        row = row - 1;
        col = numX - col;
 
        GrainPoint point;
        for (int i = 0; i < listPoints.size(); i++) {
            point = listPoints.get(i);
            if (point.getFz() == lay && point.getY() == row && point.getX() == col) {
                listPoints.remove(i);
                return GrainDataBuilder.renderTempValue(point.getTemp());
            }
        }
 
        return "--";
    }
 
    private static String getStrValue(Double tempIn) {
        if (null == tempIn) return null;
        return tempIn + "";
    }
}