From 487bbcd45afcc288c27784962d3b40d5015bcd12 Mon Sep 17 00:00:00 2001
From: maven <2163098428@qq.com>
Date: 星期五, 15 八月 2025 15:33:07 +0800
Subject: [PATCH] yys 修改导入导出
---
src/main/java/com/ruoyi/lavorissue/service/impl/LavorIssueServiceImpl.java | 88 ++++++++++++++++++++++++++++++++++++++++++-
1 files changed, 85 insertions(+), 3 deletions(-)
diff --git a/src/main/java/com/ruoyi/lavorissue/service/impl/LavorIssueServiceImpl.java b/src/main/java/com/ruoyi/lavorissue/service/impl/LavorIssueServiceImpl.java
index b6a5e27..b85975f 100644
--- a/src/main/java/com/ruoyi/lavorissue/service/impl/LavorIssueServiceImpl.java
+++ b/src/main/java/com/ruoyi/lavorissue/service/impl/LavorIssueServiceImpl.java
@@ -5,19 +5,22 @@
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.ruoyi.approve.utils.StartAndEndDateDto;
+import com.ruoyi.common.utils.excel.ExcelUtils;
import com.ruoyi.lavorissue.dto.StatisticsLaborIssue;
import com.ruoyi.lavorissue.mapper.LavorIssueMapper;
import com.ruoyi.lavorissue.pojo.LaborIssue;
import com.ruoyi.lavorissue.service.LavorIssueService;
+import com.ruoyi.project.system.domain.SysDictData;
+import com.ruoyi.project.system.domain.SysDictType;
+import com.ruoyi.project.system.mapper.SysDictDataMapper;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.util.CollectionUtils;
+import javax.servlet.http.HttpServletResponse;
import java.text.SimpleDateFormat;
-import java.util.Calendar;
-import java.util.Date;
-import java.util.List;
+import java.util.*;
import java.util.stream.Collectors;
/**
@@ -112,6 +115,85 @@
return statisticsLaborIssue;
}
+ @Autowired
+ private SysDictDataMapper sysDictDataMapper;
+
+ @Override
+ public void exportCopy(HttpServletResponse response) {
+ List<SysDictData> sys_lavor_issue = sysDictDataMapper.selectDictDataByType("sys_lavor_issue");
+ if(CollectionUtils.isEmpty(sys_lavor_issue)){
+ throw new RuntimeException("瀛楀吀鏁版嵁涓虹┖");
+ }
+ List<Object> head = new ArrayList<>();
+ head.add("閮ㄩ棬");
+ head.add(ExcelUtils.COLUMN_MERGE);
+ head.add("浼佷笟绠$悊绉�");
+ head.add(ExcelUtils.COLUMN_MERGE);
+ head.add("");
+ for (int i = 0; i < sys_lavor_issue.size(); i++) {
+ head.add(ExcelUtils.COLUMN_MERGE);
+ }
+
+ List<Object> head1 = new ArrayList<>();
+ head1.add("寮�濮嬪勾/鏈�");
+ head1.add(ExcelUtils.COLUMN_MERGE);
+ head1.add("缁撴潫骞�/鏈�");
+ head1.add(ExcelUtils.COLUMN_MERGE);
+ head1.add("");
+ for (int i = 0; i < sys_lavor_issue.size(); i++) {
+ head1.add(ExcelUtils.COLUMN_MERGE);
+ }
+
+ List<Object> head2 = new ArrayList<>();
+ head2.add("2025");
+ head2.add("1");
+ head2.add("2025");
+ head2.add("3");
+ head2.add("浼佷笟绠$悊绉�2025骞�1鏈�-2025骞�3鏈堝姵淇濆彂鏀捐鍒掕〃");
+ for (int i = 0; i < sys_lavor_issue.size(); i++) {
+ head2.add(ExcelUtils.COLUMN_MERGE);
+ }
+
+ List<Object> head3 = new ArrayList<>();
+ head3.add("閮ㄩ棬鍚嶇О");
+ head3.add(ExcelUtils.COLUMN_MERGE);
+ head3.add("濮撳悕");
+ head3.add("宸ュ彿");
+ for (SysDictData sysDictData : sys_lavor_issue) {
+ head3.add(sysDictData.getDictLabel());
+ }
+ head3.add("绛惧悕");
+
+ // 濉厖鏁版嵁
+ List<Object> head4 = new ArrayList<>();
+ List<LaborIssue> laborIssues = lavorIssueMapper.selectList(null);
+ if(CollectionUtils.isEmpty(laborIssues)){
+ throw new RuntimeException("鏁版嵁涓虹┖");
+ }
+
+ Map<String, List<LaborIssue>> collect = laborIssues.stream().collect(Collectors.groupingBy(LaborIssue::getStaffNo));
+ collect.forEach((k,v)->{
+ head4.add(v.get(0).getDeptName());
+ head4.add(ExcelUtils.COLUMN_MERGE);
+ head4.add(v.get(0).getStaffName());
+ head4.add(v.get(0).getStaffNo());
+ // 鍒ゆ柇瀛楀吀鏁版嵁
+ for (SysDictData sysDictData : sys_lavor_issue) {
+ long sum = v.stream().filter(laborIssue -> laborIssue.getDictId().equals(sysDictData.getDictValue())).mapToLong(LaborIssue::getNum).sum();
+ head4.add(sum);
+ }
+
+ });
+
+ List<List<Object>> sheetDataList = new ArrayList<>();
+ sheetDataList.add(head);
+ sheetDataList.add(head1);
+ sheetDataList.add(head2);
+ sheetDataList.add(head3);
+ sheetDataList.add(head4);
+ ExcelUtils.export(response, "鍔充繚鍙戞斁璁″垝琛�", sheetDataList);
+ }
+
public Date getLastDayOfMonth(Date date) {
Calendar calendar = Calendar.getInstance();
calendar.setTime(date); // 璁剧疆浼犲叆鐨凞ate
--
Gitblit v1.9.3