SmartEvaluateStudentController.java 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430
  1. package com.template.controller;
  2. import com.alibaba.fastjson.JSONObject;
  3. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  4. import com.template.annotation.DESRespondSecret;
  5. import com.template.annotation.PassToken;
  6. import com.template.api.SmartEvaluateStudentControllerAPI;
  7. import com.template.common.jh.ReqRespResearchProductQuestionnaireItem;
  8. import com.template.common.jh.SectionUtil;
  9. import com.template.common.utils.ExcelUtils;
  10. import com.template.common.utils.UUIDUtil;
  11. import com.template.common.utils.paramUtils;
  12. import com.template.model.evaluate.student.*;
  13. import com.template.model.evaluate.teacher.SimpleScore;
  14. import com.template.model.evaluate.teacher.SmartEvaluateTdetail;
  15. import com.template.model.evaluate.teacher.SmartEvaluateTeacher;
  16. import com.template.model.result.CommonResult;
  17. import com.template.model.result.PageUtils;
  18. import com.template.model.vo.HistoricalEvaluationVo;
  19. import com.template.model.vo.TemplateRuleVo;
  20. import com.template.services.*;
  21. import org.apache.poi.ss.usermodel.Row;
  22. import org.apache.poi.ss.usermodel.Sheet;
  23. import org.apache.poi.ss.usermodel.Workbook;
  24. import org.apache.poi.xssf.usermodel.XSSFWorkbook;
  25. import org.slf4j.Logger;
  26. import org.slf4j.LoggerFactory;
  27. import org.springframework.beans.factory.annotation.Autowired;
  28. import org.springframework.validation.BindingResult;
  29. import org.springframework.web.bind.annotation.RestController;
  30. import javax.servlet.http.HttpServletResponse;
  31. import java.util.*;
  32. import java.util.stream.Collectors;
  33. @RestController
  34. //返回参数加密注解
  35. @DESRespondSecret
  36. public class SmartEvaluateStudentController implements SmartEvaluateStudentControllerAPI {
  37. private static Logger logger = LoggerFactory.getLogger(SmartEvaluateStudentController.class);
  38. @Autowired
  39. private SmartSubjectManageService smartSubjectManageService;
  40. @Autowired
  41. private SmartSubjectRuleService smartSubjectRuleService;
  42. @Autowired
  43. private SmartEvaluateStudentService smartEvaluateStudentService;
  44. @Autowired
  45. private SmartEvaluateSdetailService smartEvaluateSdetailService;
  46. @Autowired
  47. private SmartTemplateRuleService smartTemplateRuleService;
  48. @PassToken
  49. public CommonResult operateSmartSubjectManage(JSONObject jsonObject) {
  50. SubjectManageList subjectManageList = null;
  51. try {
  52. subjectManageList = JSONObject.parseObject(jsonObject.toString(), SubjectManageList.class);
  53. } catch (Exception e) {
  54. return CommonResult.errorMsg("参数格式错误");
  55. }
  56. List<SmartSubjectManage> allList = subjectManageList.getSubjectList();
  57. logger.info("===" + allList);
  58. List<String> subjectLists = allList.stream().filter(e -> e.getDeleted() == 0).map(m -> m.getTerm() + m.getName()).collect(Collectors.toList());
  59. Set<String> mainScoreSet = new HashSet<>(subjectLists);
  60. if (subjectLists.size() != mainScoreSet.size()) {
  61. return CommonResult.fail("存在重复学科");
  62. }
  63. QueryWrapper<SmartEvaluateSdetail> queryWrapper1 = new QueryWrapper<>();
  64. queryWrapper1.eq("term", allList.get(0).getTerm());
  65. List<SmartEvaluateSdetail> smartEvaluateTdetails = smartEvaluateSdetailService.getSmartEvaluateSdetailByKey(queryWrapper1);
  66. if (smartEvaluateTdetails.size() > 0) {
  67. return CommonResult.fail("该学期已有评测数据,不可再更改");
  68. }
  69. for (int i = 0; i < allList.size(); i++) {
  70. SmartSubjectManage smartSubjectManage = allList.get(i);
  71. if (smartSubjectManage.getId() == null) {
  72. smartSubjectManage.setId((int) UUIDUtil.generateID());
  73. }
  74. SmartSubjectManage listc = smartSubjectManageService.getSmartSubjectManageById(smartSubjectManage.getId());
  75. if (listc == null) {
  76. smartSubjectManageService.insertSmartSubjectManage(smartSubjectManage);
  77. } else {
  78. smartSubjectManageService.updateSmartSubjectManage(smartSubjectManage);
  79. }
  80. }
  81. return CommonResult.ok("操作成功");
  82. }
  83. @PassToken
  84. public CommonResult querySubjectManage(String term) {
  85. if (term == null) {
  86. term = smartSubjectManageService.getMaxTerm();
  87. }
  88. QueryWrapper<SmartSubjectManage> queryWrapper1 = new QueryWrapper<>();
  89. queryWrapper1.eq("term", term);
  90. List<SmartSubjectManage> list = smartSubjectManageService.getSmartSubjectManageByKey(queryWrapper1);
  91. JSONObject jsonObject = new JSONObject();
  92. jsonObject.put("subjectList", list);
  93. return CommonResult.ok(jsonObject);
  94. }
  95. @PassToken
  96. public CommonResult operateSmartSubjectRule(JSONObject jsonObject) {
  97. SmartSubjectRuleOutList smartSubjectRuleOutList = null;
  98. try {
  99. smartSubjectRuleOutList = JSONObject.parseObject(jsonObject.toString(), SmartSubjectRuleOutList.class);
  100. } catch (Exception e) {
  101. return CommonResult.errorMsg("参数格式错误");
  102. }
  103. List<SmartSubjectRuleInList> outList = smartSubjectRuleOutList.getSmartSubjectRuleInLists();
  104. List<SmartSubjectRule> data = new ArrayList<>();
  105. for (int i = 0; i < outList.size(); i++) {
  106. String subjectName = outList.get(i).getSubjectName();
  107. String term = outList.get(i).getTerm();
  108. List<SmartSubjectRule> smartSubjectRules = outList.get(i).getSubjectRuleList();
  109. List<String> ruleList = smartSubjectRules.stream().filter(e -> e.getDeleted() == 0).map(SmartSubjectRule::getLevel).collect(Collectors.toList());
  110. Set<String> ruleSet = new HashSet<>(ruleList);
  111. if (ruleList.size() != ruleSet.size()) {
  112. return CommonResult.fail("存在重复等级");
  113. }
  114. List<String> rangeList = smartSubjectRules.stream().filter(e -> e.getDeleted() == 0).map(SmartSubjectRule::getScoreRange).collect(Collectors.toList());
  115. List<ReqRespResearchProductQuestionnaireItem> all = new ArrayList<>();
  116. for (int j = 0; j < rangeList.size(); j++) {
  117. String[] ls = rangeList.get(j).split("-");
  118. ReqRespResearchProductQuestionnaireItem re = new ReqRespResearchProductQuestionnaireItem(ls[0], ls[1], (byte) 7);
  119. all.add(re);
  120. }
  121. if (SectionUtil.compareSection(all)) {
  122. return CommonResult.fail("存在重复区间");
  123. }
  124. for (int j = 0; j < smartSubjectRules.size(); j++) {
  125. SmartSubjectRule smartSubjectRule = smartSubjectRules.get(j);
  126. if (smartSubjectRule.getId() == null) {
  127. smartSubjectRule.setId((int) UUIDUtil.generateID());
  128. }
  129. smartSubjectRule.setSubjectName(subjectName);
  130. smartSubjectRule.setTerm(term);
  131. data.add(smartSubjectRule);
  132. }
  133. }
  134. for (int i = 0; i < data.size(); i++) {
  135. SmartSubjectRule smartSubjectRule = data.get(i);
  136. SmartSubjectRule rule = smartSubjectRuleService.getSmartSubjectRuleById(smartSubjectRule.getId());
  137. if (rule == null) {
  138. smartSubjectRuleService.insertSmartSubjectRule(smartSubjectRule);
  139. } else {
  140. smartSubjectRuleService.updateSmartSubjectRule(smartSubjectRule);
  141. }
  142. }
  143. return CommonResult.ok("操作成功");
  144. }
  145. @PassToken
  146. public CommonResult querySubjectRule(String term) {
  147. if (term == null) {
  148. term = smartSubjectManageService.getMaxTerm();
  149. }
  150. QueryWrapper<SmartSubjectManage> queryWrapper1 = new QueryWrapper<>();
  151. queryWrapper1.eq("term", term);
  152. queryWrapper1.eq("shows", 1);
  153. List<SmartSubjectManage> list = smartSubjectManageService.getSmartSubjectManageByKey(queryWrapper1);
  154. JSONObject jsonObject1 = new JSONObject();
  155. List<JSONObject> lj = new ArrayList<>();
  156. for (int i = 0; i < list.size(); i++) {
  157. QueryWrapper<SmartSubjectRule> queryWrapper2 = new QueryWrapper<>();
  158. queryWrapper2.eq("term", term);
  159. queryWrapper2.eq("subject_name", list.get(i).getName());
  160. List<SmartSubjectRule> list2 = smartSubjectRuleService.getSmartSubjectRuleByKey(queryWrapper2);
  161. JSONObject jsonObject2 = new JSONObject();
  162. jsonObject2.put("subjectName", list.get(i).getName());
  163. jsonObject2.put("term", term);
  164. jsonObject2.put("subjectRuleList", list2);
  165. lj.add(jsonObject2);
  166. jsonObject1.put("smartSubjectRuleInLists", lj);
  167. }
  168. return CommonResult.ok(jsonObject1);
  169. }
  170. @PassToken
  171. public CommonResult queryEvaluateStudent(SmartEvaluateStudent smartEvaluateStudent, Integer currentPage, Integer pageCount) {
  172. QueryWrapper<SmartEvaluateStudent> queryWrapper1 = new QueryWrapper<>();
  173. if (smartEvaluateStudent.getName() != null && !smartEvaluateStudent.getName().trim().equals("")) {
  174. queryWrapper1.and(qw -> qw.like("name", smartEvaluateStudent.getName()).or().like("card_no", smartEvaluateStudent.getName()));
  175. }
  176. if (smartEvaluateStudent.getTerm() != null && !smartEvaluateStudent.getTerm().trim().equals("")) {
  177. queryWrapper1.eq("term_id", smartEvaluateStudent.getTerm());
  178. }
  179. if (smartEvaluateStudent.getGradeName() != null && !smartEvaluateStudent.getGradeName().trim().equals("")) {
  180. queryWrapper1.eq("grade_name", smartEvaluateStudent.getGradeName());
  181. }
  182. if (smartEvaluateStudent.getClassName() != null && !smartEvaluateStudent.getClassName().trim().equals("")) {
  183. queryWrapper1.eq("class_name", smartEvaluateStudent.getClassName());
  184. }
  185. if (smartEvaluateStudent.getScoreLevel() != null && !smartEvaluateStudent.getScoreLevel().trim().equals("")) {
  186. queryWrapper1.eq("score_level", smartEvaluateStudent.getClassName());
  187. }
  188. queryWrapper1.orderByDesc("id");
  189. PageUtils<SmartEvaluateStudent> list = smartEvaluateStudentService.queryPageSmartEvaluateStudent(currentPage, pageCount, queryWrapper1);
  190. if (list.getList() != null && list.getList().size() > 0) {
  191. List<Integer> gradeIds = list.getList().stream().map(SmartEvaluateStudent::getGradeId).distinct().collect(Collectors.toList());
  192. List<Integer> termIds = list.getList().stream().map(SmartEvaluateStudent::getTermId).distinct().collect(Collectors.toList());
  193. List<TemplateRuleVo> templateRules = smartTemplateRuleService.queryTemplateRuleByIds(gradeIds, termIds);
  194. for (SmartEvaluateStudent student : list.getList()) {
  195. List<TemplateRuleVo> ownerRules = templateRules.stream().filter(e -> e.getGradeId().equals(student.getGradeId())
  196. && e.getTermId().equals(student.getTermId())).collect(Collectors.toList());
  197. if (ownerRules != null && ownerRules.size() > 0) {
  198. for (TemplateRuleVo ownerRule : ownerRules) {
  199. Integer minValue = 0;
  200. Integer maxValue = 0;
  201. String[] levels = ownerRule.getScoreRange().split("-");
  202. if (Integer.valueOf(levels[0]).intValue() > Integer.valueOf(levels[1]).intValue()) {
  203. minValue = Integer.valueOf(levels[1]).intValue();
  204. maxValue = Integer.valueOf(levels[0]).intValue();
  205. }else{
  206. minValue = Integer.valueOf(levels[0]).intValue();
  207. maxValue = Integer.valueOf(levels[1]).intValue();
  208. }
  209. Double scoreNum = (double) student.getScoreNum() / student.getSubjectNum();
  210. if(scoreNum >= minValue && scoreNum <= maxValue){
  211. student.setScoreLevel(ownerRule.getLevel());
  212. }
  213. }
  214. }
  215. }
  216. }
  217. return CommonResult.ok(list);
  218. }
  219. @PassToken
  220. public CommonResult evaluateScore(JSONObject jsonObject) {
  221. SmartEvaluateSdetailList smartEvaluateSdetailList = null;
  222. try {
  223. smartEvaluateSdetailList = JSONObject.parseObject(jsonObject.toString(), SmartEvaluateSdetailList.class);
  224. } catch (Exception e) {
  225. return CommonResult.errorMsg("参数格式错误");
  226. }
  227. Integer id = smartEvaluateSdetailList.getId();
  228. List<SmartEvaluateSdetail> scoreList = smartEvaluateSdetailList.getScoreList();
  229. SmartEvaluateStudent student = smartEvaluateStudentService.getSmartEvaluateStudentById(id);
  230. double total = 0;
  231. for (int i = 0; i < scoreList.size(); i++) {
  232. SmartEvaluateSdetail smartEvaluateSdetail = scoreList.get(i);
  233. if (smartEvaluateSdetail.getId() == null) {
  234. smartEvaluateSdetail.setId((int) UUIDUtil.generateID());
  235. }
  236. if (smartEvaluateSdetail.getDeleted() == 0) {
  237. total += smartEvaluateSdetail.getScoreNum();
  238. }
  239. smartEvaluateSdetail.setTerm(student.getTerm());
  240. smartEvaluateSdetail.setCardNo(student.getCardNo());
  241. QueryWrapper<SmartSubjectRule> queryWrapper1 = new QueryWrapper<>();
  242. queryWrapper1.eq("subject_name", smartEvaluateSdetail.getSubjectName());
  243. List<SmartSubjectRule> rule = smartSubjectRuleService.getSmartSubjectRuleByKey(queryWrapper1);
  244. String scoreLevel = "";
  245. for (int j = 0; j < rule.size(); j++) {
  246. String[] range = rule.get(j).getScoreRange().split("-");
  247. double min = Double.parseDouble(range[0]);
  248. double max = Double.parseDouble(range[1]);
  249. if (smartEvaluateSdetail.getScoreNum() >= min && smartEvaluateSdetail.getScoreNum() <= max) {
  250. scoreLevel = rule.get(j).getLevel();
  251. break;
  252. }
  253. }
  254. smartEvaluateSdetail.setScoreLevel(scoreLevel);
  255. SmartEvaluateSdetail listc = smartEvaluateSdetailService.getSmartEvaluateSdetailById(smartEvaluateSdetail.getId());
  256. if (listc == null) {
  257. smartEvaluateSdetailService.insertSmartEvaluateSdetail(smartEvaluateSdetail);
  258. } else {
  259. smartEvaluateSdetailService.updateSmartEvaluateSdetail(smartEvaluateSdetail);
  260. }
  261. }
  262. student.setScoreComment(smartEvaluateSdetailList.getScoreComment());
  263. student.setScoreNum(total / scoreList.size());
  264. String scoreLevel = "";
  265. QueryWrapper<SmartSubjectRule> queryWrapper2 = new QueryWrapper<>();
  266. queryWrapper2.eq("subject_name", "平均成绩");
  267. List<SmartSubjectRule> rule = smartSubjectRuleService.getSmartSubjectRuleByKey(queryWrapper2);
  268. for (int i = 0; i < rule.size(); i++) {
  269. String[] range = rule.get(i).getScoreRange().split("-");
  270. double min = Double.parseDouble(range[0]);
  271. double max = Double.parseDouble(range[1]);
  272. if (student.getScoreNum() >= min && student.getScoreNum() <= max) {
  273. scoreLevel = rule.get(i).getLevel();
  274. break;
  275. }
  276. }
  277. student.setScoreLevel(scoreLevel);
  278. smartEvaluateStudentService.updateSmartEvaluateStudent(student);
  279. return CommonResult.ok();
  280. }
  281. @PassToken
  282. public CommonResult queryDetailScore(Integer id) {
  283. if (id == null) {
  284. return CommonResult.fail("请传入id");
  285. }
  286. SmartEvaluateStudent smartEvaluateStudent = smartEvaluateStudentService.getSmartEvaluateStudentById(id);
  287. if (smartEvaluateStudent == null) {
  288. return CommonResult.fail("未查询到相关信息");
  289. }
  290. QueryWrapper<SmartEvaluateSdetail> queryWrapper1 = new QueryWrapper<>();
  291. queryWrapper1.eq("term", smartEvaluateStudent.getTerm());
  292. queryWrapper1.eq("card_no", smartEvaluateStudent.getCardNo());
  293. List<SmartEvaluateSdetail> list = smartEvaluateSdetailService.getSmartEvaluateSdetailByKey(queryWrapper1);
  294. JSONObject jsonObject = new JSONObject();
  295. jsonObject.put("id", smartEvaluateStudent.getId());
  296. jsonObject.put("scoreComment", smartEvaluateStudent.getScoreComment());
  297. jsonObject.put("scoreList", list);
  298. return CommonResult.ok(jsonObject);
  299. }
  300. @Override
  301. @DESRespondSecret(validated = true)
  302. public CommonResult historicalEvaluation(String cardNo) {
  303. List<HistoricalEvaluationVo> vos = smartEvaluateStudentService.getHistoricalEvaluation(cardNo);
  304. // 获取评级
  305. for (int i = 0; i < vos.size(); i++) {
  306. HistoricalEvaluationVo vo = vos.get(i);
  307. String term = vo.getTerm();
  308. String scoreNum = vo.getScoreNum();
  309. QueryWrapper<SmartSubjectRule> queryWrapper1 = new QueryWrapper<>();
  310. queryWrapper1.eq("subject_name", "平均成绩");
  311. queryWrapper1.eq("term", term);
  312. List<SmartSubjectRule> rule = smartSubjectRuleService.list(queryWrapper1);
  313. for (int j = 0; j < rule.size(); j++) {
  314. String[] range = rule.get(j).getScoreRange().split("-");
  315. double min = Double.parseDouble(range[0]);
  316. double max = Double.parseDouble(range[1]);
  317. Double num = Double.valueOf(scoreNum);
  318. if (num >= min && num <= max) {
  319. String scoreLevel = rule.get(j).getLevel();
  320. vo.setScoreLevel(scoreLevel);
  321. break;
  322. }
  323. }
  324. }
  325. return CommonResult.ok(vos);
  326. }
  327. @Override
  328. public CommonResult getSEvaluationExcel(SmartEvaluateStudent smartEvaluateStudent, HttpServletResponse response, BindingResult bindingResult) {
  329. if (bindingResult.hasErrors()) {
  330. String st = paramUtils.getParamError(bindingResult);
  331. return CommonResult.fail(st);
  332. }
  333. //导出
  334. Workbook workbook = new XSSFWorkbook();
  335. Sheet sheet = workbook.createSheet("学生综评管理");
  336. Row headerRow = sheet.createRow(0);
  337. headerRow.createCell(0).setCellValue("序号");
  338. headerRow.createCell(1).setCellValue("学期");
  339. headerRow.createCell(2).setCellValue("年级");
  340. headerRow.createCell(3).setCellValue("班级");
  341. headerRow.createCell(4).setCellValue("姓名");
  342. headerRow.createCell(5).setCellValue("测评等级");
  343. headerRow.createCell(6).setCellValue("教师寄语");
  344. QueryWrapper<SmartEvaluateStudent> queryWrapper1 = new QueryWrapper<>();
  345. if (smartEvaluateStudent.getName() != null && !smartEvaluateStudent.getName().trim().equals("")) {
  346. queryWrapper1.and(qw -> qw.like("name", smartEvaluateStudent.getName()).or().like("card_no", smartEvaluateStudent.getName()));
  347. }
  348. if (smartEvaluateStudent.getTerm() != null && !smartEvaluateStudent.getTerm().trim().equals("")) {
  349. queryWrapper1.eq("term_id", smartEvaluateStudent.getTerm());
  350. }
  351. if (smartEvaluateStudent.getGradeName() != null && !smartEvaluateStudent.getGradeName().trim().equals("")) {
  352. queryWrapper1.eq("grade_name", smartEvaluateStudent.getGradeName());
  353. }
  354. if (smartEvaluateStudent.getClassName() != null && !smartEvaluateStudent.getClassName().trim().equals("")) {
  355. queryWrapper1.eq("class_name", smartEvaluateStudent.getClassName());
  356. }
  357. if (smartEvaluateStudent.getScoreLevel() != null && !smartEvaluateStudent.getScoreLevel().trim().equals("")) {
  358. queryWrapper1.eq("score_level", smartEvaluateStudent.getClassName());
  359. }
  360. queryWrapper1.orderByDesc("id");
  361. List<SmartEvaluateStudent> list = smartEvaluateStudentService.queryPageSmartEvaluateStudent(queryWrapper1);
  362. if (list != null && list.size() > 0) {
  363. List<Integer> gradeIds = list.stream().map(SmartEvaluateStudent::getGradeId).distinct().collect(Collectors.toList());
  364. List<Integer> termIds = list.stream().map(SmartEvaluateStudent::getTermId).distinct().collect(Collectors.toList());
  365. List<TemplateRuleVo> templateRules = smartTemplateRuleService.queryTemplateRuleByIds(gradeIds, termIds);
  366. int i = 0;
  367. for (SmartEvaluateStudent student : list) {
  368. List<TemplateRuleVo> ownerRules = templateRules.stream().filter(e -> e.getGradeId().equals(student.getGradeId())
  369. && e.getTermId().equals(student.getTermId())).collect(Collectors.toList());
  370. if (ownerRules != null && ownerRules.size() > 0) {
  371. for (TemplateRuleVo ownerRule : ownerRules) {
  372. Integer minValue = 0;
  373. Integer maxValue = 0;
  374. String[] levels = ownerRule.getScoreRange().split("-");
  375. if (Integer.valueOf(levels[0]).intValue() > Integer.valueOf(levels[1]).intValue()) {
  376. minValue = Integer.valueOf(levels[1]).intValue();
  377. maxValue = Integer.valueOf(levels[0]).intValue();
  378. }else{
  379. minValue = Integer.valueOf(levels[0]).intValue();
  380. maxValue = Integer.valueOf(levels[1]).intValue();
  381. }
  382. Double scoreNum = (double) student.getScoreNum() / student.getSubjectNum();
  383. if(scoreNum >= minValue && scoreNum <= maxValue){
  384. student.setScoreLevel(ownerRule.getLevel());
  385. }
  386. }
  387. }
  388. Row dataRow = sheet.createRow(i + 1);
  389. dataRow.createCell(0).setCellValue(i + 1);
  390. dataRow.createCell(1).setCellValue(student.getTerm());
  391. dataRow.createCell(2).setCellValue(student.getGradeName());
  392. dataRow.createCell(3).setCellValue(student.getClassName());
  393. dataRow.createCell(4).setCellValue(student.getName());
  394. dataRow.createCell(5).setCellValue(student.getScoreLevel());
  395. dataRow.createCell(6).setCellValue(student.getScoreComment());
  396. i++;
  397. }
  398. }
  399. // 将工作簿写入文件
  400. ExcelUtils.excelDownload(workbook, "学生综评管理.xlsx", response);
  401. return CommonResult.ok("导出成功");
  402. }
  403. }