BaseClassCourseServiceImpl.java 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461
  1. package com.xjrsoft.module.base.service.impl;
  2. import com.alibaba.excel.EasyExcel;
  3. import com.alibaba.excel.support.ExcelTypeEnum;
  4. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  5. import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
  6. import com.github.yulichang.base.MPJBaseServiceImpl;
  7. import com.github.yulichang.wrapper.MPJLambdaWrapper;
  8. import com.xjrsoft.common.enums.ArchivesStatusEnum;
  9. import com.xjrsoft.common.enums.DeleteMark;
  10. import com.xjrsoft.common.enums.UseSemesterTypeEnum;
  11. import com.xjrsoft.common.exception.MyException;
  12. import com.xjrsoft.common.utils.VoToColumnUtil;
  13. import com.xjrsoft.module.base.dto.BaseClassCoursePageDto;
  14. import com.xjrsoft.module.base.dto.ClassCourseReuseDto;
  15. import com.xjrsoft.module.base.entity.*;
  16. import com.xjrsoft.module.base.mapper.BaseClassCourseMapper;
  17. import com.xjrsoft.module.base.mapper.BaseClassMapper;
  18. import com.xjrsoft.module.base.service.IBaseClassCourseService;
  19. import com.xjrsoft.module.base.vo.BaseClassCourseExportListVo;
  20. import com.xjrsoft.module.base.vo.BaseClassCoursePageVo;
  21. import com.xjrsoft.module.generator.entity.ImportConfig;
  22. import com.xjrsoft.module.organization.entity.Department;
  23. import com.xjrsoft.module.student.entity.BaseStudentSchoolRoll;
  24. import com.xjrsoft.module.student.mapper.BaseStudentSchoolRollMapper;
  25. import com.xjrsoft.module.base.dto.ClassCourseTextbookExportQueryDto;
  26. import com.xjrsoft.module.base.vo.ClassCourseTextbookExportQueryVo;
  27. import com.xjrsoft.module.system.entity.DictionaryDetail;
  28. import com.xjrsoft.module.textbook.entity.Textbook;
  29. import com.xjrsoft.module.textbook.entity.TextbookStudentClaim;
  30. import com.xjrsoft.module.textbook.mapper.TextbookStudentClaimMapper;
  31. import lombok.AllArgsConstructor;
  32. import org.apache.commons.lang3.ObjectUtils;
  33. import org.apache.commons.lang3.StringUtils;
  34. import org.apache.poi.ss.usermodel.*;
  35. import org.apache.poi.ss.util.CellRangeAddress;
  36. import org.apache.poi.xssf.usermodel.XSSFWorkbook;
  37. import org.springframework.stereotype.Service;
  38. import org.springframework.transaction.annotation.Transactional;
  39. import java.io.ByteArrayOutputStream;
  40. import java.io.IOException;
  41. import java.math.BigDecimal;
  42. import java.util.*;
  43. import java.util.stream.Collectors;
  44. import static com.xjrsoft.module.veb.util.ImportExcelUtil.allFields;
  45. import static com.xjrsoft.module.veb.util.ImportExcelUtil.createHead;
  46. /**
  47. * @title: 班级课程
  48. * @Author brealinxx
  49. * @Date: 2024-06-04
  50. * @Version 1.0
  51. */
  52. @Service
  53. @AllArgsConstructor
  54. public class BaseClassCourseServiceImpl extends MPJBaseServiceImpl<BaseClassCourseMapper, BaseClassCourse> implements IBaseClassCourseService {
  55. private final BaseClassCourseMapper baseClassCourseMapper;
  56. private final BaseStudentSchoolRollMapper baseStudentSchoolRollMapper;
  57. private final TextbookStudentClaimMapper textbookStudentClaimMapper;
  58. private final BaseClassMapper baseClassMapper;
  59. @Override
  60. public Page<BaseClassCoursePageVo> getPage(Page<BaseClassCoursePageVo> page, BaseClassCoursePageDto dto) {
  61. return baseClassCourseMapper.getPage(page, dto);
  62. }
  63. @Override
  64. public List<CourseBookInfo> getAllCourseBook(Long[] classIds, Long subjectGroupId, Long semester){
  65. return baseClassCourseMapper.getAllCourseBook(classIds, subjectGroupId, semester);
  66. }
  67. @Override
  68. public List<CourseBookInfo> getSelectedCourseBook(Long[] subjectGroupId, Long semester){
  69. return baseClassCourseMapper.getSelectedCourseBook(subjectGroupId, semester);
  70. }
  71. @Override
  72. @Transactional
  73. public Boolean updateAddCourseBook(ClassCourseTextbook dto){
  74. if (dto.getClassIds() == null || dto.getClassIds().length == 0 || dto.getBaseSemesterId() == null || dto.getBaseSemesterId() == 0) {
  75. return false;
  76. }
  77. boolean isSuccess = false;
  78. List<Long> classIdList = Arrays.asList(dto.getClassIds());
  79. //删除班级的这学期的所有课程教材
  80. LambdaQueryWrapper<BaseClassCourse> baseClassCourseLambdaQueryWrapper = new LambdaQueryWrapper<>();
  81. baseClassCourseLambdaQueryWrapper
  82. .in(BaseClassCourse::getClassId, classIdList)
  83. .eq(BaseClassCourse::getBaseSemesterId, dto.getBaseSemesterId())
  84. ;
  85. isSuccess = this.remove(baseClassCourseLambdaQueryWrapper);
  86. // 获取所有班级的所有学生
  87. LambdaQueryWrapper<BaseStudentSchoolRoll> baseStudentSchoolRollLambdaQueryWrapper = new LambdaQueryWrapper<>();
  88. baseStudentSchoolRollLambdaQueryWrapper
  89. .in(BaseStudentSchoolRoll::getClassId, classIdList)
  90. .eq(BaseStudentSchoolRoll::getArchivesStatus, ArchivesStatusEnum.FB2901.getCode())
  91. ;
  92. List<BaseStudentSchoolRoll> baseStudentSchoolRolls = baseStudentSchoolRollMapper.selectList(baseStudentSchoolRollLambdaQueryWrapper);
  93. Map<Long, List<Long>> userIdsMap = baseStudentSchoolRolls.stream()
  94. .filter(student -> student.getClassId() != null && student.getUserId() != null)
  95. .collect(Collectors.groupingBy(
  96. BaseStudentSchoolRoll::getClassId, // 根据classId分组
  97. Collectors.mapping(BaseStudentSchoolRoll::getUserId, // 提取userId
  98. Collectors.toList()) // 收集到List<Long>
  99. )
  100. );
  101. List<BaseClassCourse> baseClassCourseList = new ArrayList<>();
  102. List<TextbookStudentClaim> textbookStudentClaimList = new ArrayList<>();
  103. for (Long classId : dto.getClassIds()) {
  104. for (String id : dto.getIds()) {
  105. String[] idArr = id.split("_");
  106. if (idArr[0].equals("") || idArr[1].equals("")) {
  107. continue;
  108. }
  109. Long courseId = Long.parseLong(idArr[0]);
  110. Long textbookId = Long.parseLong(idArr[1]);
  111. baseClassCourseList.add(new BaseClassCourse() {{
  112. setBaseSemesterId(dto.getBaseSemesterId());
  113. setClassId(classId);
  114. setCourseId(courseId);
  115. setTextbookId(textbookId);
  116. }});
  117. // 添加学生领取教材数据
  118. List<Long> userIds = userIdsMap.get(classId);
  119. for (Long userId : userIds) {
  120. textbookStudentClaimList.add(new TextbookStudentClaim() {{
  121. setStudentUserId(userId);
  122. setBaseSemesterId(dto.getBaseSemesterId());
  123. setClassId(classId);
  124. setTextbookId(textbookId);
  125. }});
  126. }
  127. }
  128. }
  129. for (TextbookStudentClaim textbookStudentClaim : textbookStudentClaimList) {
  130. textbookStudentClaimMapper.insert(textbookStudentClaim);
  131. }
  132. return this.saveBatch(baseClassCourseList);
  133. }
  134. @Override
  135. public void updateRemoveCourseBook(Long classId, Long courseId, Long textbookId){
  136. baseClassCourseMapper.updateRemoveClassCourseTextbooks(classId, courseId, textbookId);
  137. }
  138. @Override
  139. public void markExistingRecordsAsDeleted(Long newClassId, Long sourceClassId){
  140. baseClassCourseMapper.markExistingRecordsAsDeleted(newClassId, sourceClassId);
  141. }
  142. @Override
  143. @Transactional
  144. public Boolean duplicateCourseBook(ClassCourseReuseDto dto){
  145. LambdaQueryWrapper<BaseClassCourse> baseClassCourseLambdaQueryWrapper = new LambdaQueryWrapper<>();
  146. baseClassCourseLambdaQueryWrapper
  147. .eq(dto.getOldClassId() != null && dto.getOldClassId() > 0, BaseClassCourse::getClassId, dto.getOldClassId())
  148. .eq(dto.getOldBaseSemesterId() != null && dto.getOldBaseSemesterId() > 0, BaseClassCourse::getBaseSemesterId, dto.getOldBaseSemesterId())
  149. ;
  150. List<BaseClassCourse> baseClassCourseList = this.list(baseClassCourseLambdaQueryWrapper);
  151. if(baseClassCourseList == null || baseClassCourseList.isEmpty()){
  152. throw new MyException("该学期的该班级没有可以复用的课程!");
  153. }
  154. boolean isSuccess = false;
  155. //删除班级的所有课程教材
  156. LambdaQueryWrapper<BaseClassCourse> removeLambdaQueryWrapper = new LambdaQueryWrapper<>();
  157. removeLambdaQueryWrapper
  158. .in(BaseClassCourse::getClassId, dto.getNewClassIds())
  159. .eq(BaseClassCourse::getBaseSemesterId, dto.getNewBaseSemesterId())
  160. ;
  161. isSuccess = this.remove(removeLambdaQueryWrapper);
  162. List<BaseClassCourse> newBaseClassCourseList = new ArrayList<>();
  163. for (Long newClassId : dto.getNewClassIds()){
  164. for (BaseClassCourse baseClassCourse : baseClassCourseList){
  165. Long courseId = baseClassCourse.getCourseId();
  166. Long textbookId = baseClassCourse.getTextbookId();
  167. newBaseClassCourseList.add(new BaseClassCourse(){{
  168. setBaseSemesterId(dto.getNewBaseSemesterId());
  169. setClassId(newClassId);
  170. setCourseId(courseId);
  171. setTextbookId(textbookId);
  172. }});
  173. }
  174. }
  175. isSuccess = this.saveBatch(newBaseClassCourseList);
  176. return isSuccess;
  177. //baseClassCourseMapper.insertClassCourseTextbookCombinations(newClassId, sourceClassId, semester);
  178. }
  179. @Override
  180. public Map<String, Map<String, Object>> getSemesterTree() {
  181. List<Map<String, Object>> semesterData = baseClassCourseMapper.getAllSemesterNames();
  182. Map<String, Map<String, Object>> tree = new TreeMap<>();
  183. for (Map<String, Object> data : semesterData) {
  184. String name = (String) data.get("name");
  185. String[] parts = name.split("年");
  186. String year = parts[0]; // 年份
  187. String semesterType = parts[1].substring(0, parts[1].length() - 1); // 学期类型(春期/秋期)
  188. Long id = Long.parseLong(data.get("id").toString());
  189. if (!tree.containsKey(year + "年")) {
  190. tree.put(year + "年", new HashMap<>());
  191. }
  192. Map<String, Object> yearMap = tree.get(year + "年");
  193. if (semesterType.equals("春")) {
  194. yearMap.put("springName", name);
  195. yearMap.put("springId", id);
  196. } else if (semesterType.equals("秋")) {
  197. yearMap.put("autumnName", name);
  198. yearMap.put("autumnId", id);
  199. }
  200. }
  201. return tree;
  202. }
  203. @Override
  204. public Long GetClassIdByName(String name){
  205. return baseClassCourseMapper.getClassIdByName(name);
  206. }
  207. @Override
  208. public Long GetCourseIdByName(String name){
  209. return baseClassCourseMapper.getCourseIdByName(name);
  210. }
  211. @Override
  212. public Long GetTextbookIdByName(String name){
  213. return baseClassCourseMapper.getBookIdByName(name);
  214. }
  215. @Override
  216. public Long GetBaseSemesterIdByName(String name) {
  217. return baseClassCourseMapper.getBaseSemesterIdByName(name);
  218. }
  219. @Override
  220. public boolean checkExits(Long classId,Long courseId,Long textbookId){
  221. return baseClassCourseMapper.checkExits(classId, courseId, textbookId);
  222. }
  223. @Override
  224. public boolean checkExitsWithoutTextbook(Long classId, Long courseId) {
  225. return this.baseMapper.checkExitsWithoutTextbook(classId, courseId);
  226. }
  227. @Override
  228. public ByteArrayOutputStream classCourseTextbookExportQuery(ClassCourseTextbookExportQueryDto dto) throws IOException {
  229. MPJLambdaWrapper<BaseClass> baseClassCourseMPJLambdaWrapper = new MPJLambdaWrapper<>();
  230. baseClassCourseMPJLambdaWrapper
  231. .disableSubLogicDel()
  232. .selectAs(BaseSemester::getName, ClassCourseTextbookExportQueryVo::getSemester)
  233. .selectAs(Department::getName, ClassCourseTextbookExportQueryVo::getDeptName)
  234. .selectAs(BaseClass::getId, ClassCourseTextbookExportQueryVo::getClassId)
  235. .selectAs(BaseClass::getName, ClassCourseTextbookExportQueryVo::getClassName)
  236. .selectAs(BaseCourseSubject::getName, ClassCourseTextbookExportQueryVo::getCourseName)
  237. .selectAs(Textbook::getBookName, ClassCourseTextbookExportQueryVo::getTextbookName)
  238. .selectAs(Textbook::getUseType, ClassCourseTextbookExportQueryVo::getUseType)
  239. .selectAs(Textbook::getPrice, ClassCourseTextbookExportQueryVo::getPrice)
  240. .selectAs(Textbook::getDiscountPrice, ClassCourseTextbookExportQueryVo::getDiscountPrice)
  241. .leftJoin(BaseClassCourse.class, BaseClassCourse::getClassId, BaseClass::getId)
  242. .leftJoin(BaseSemester.class, BaseSemester::getId, BaseClassCourse::getBaseSemesterId)
  243. .leftJoin(BaseClass.class, BaseClass::getId, BaseClassCourse::getClassId)
  244. .leftJoin(Department.class, Department::getId, BaseClass::getOrgId)
  245. .leftJoin(BaseCourseSubject.class, BaseCourseSubject::getId, BaseClassCourse::getCourseId)
  246. .leftJoin(Textbook.class, Textbook::getId, BaseClassCourse::getTextbookId)
  247. .leftJoin(DictionaryDetail.class, DictionaryDetail::getCode, Textbook::getTextbookType,
  248. wrapper -> wrapper
  249. .selectAs(DictionaryDetail::getName, ClassCourseTextbookExportQueryVo::getTextbookType)
  250. )
  251. .in(ObjectUtils.isNotEmpty(dto.getClassIds()) && !dto.getClassIds().isEmpty(), BaseClassCourse::getClassId, dto.getClassIds())
  252. .like(StringUtils.isNotBlank(dto.getClassName()), BaseClass::getName, dto.getClassName())
  253. .eq(ObjectUtils.isNotEmpty(dto.getDeptId()), Department::getId, dto.getDeptId())
  254. .having(ObjectUtils.isNotEmpty(dto.getCourseSet()) && dto.getCourseSet() == 1, "HAVING LENGTH(course_name) > 0")
  255. .having(ObjectUtils.isNotEmpty(dto.getCourseSet()) && dto.getCourseSet() == 2, "HAVING COALESCE(LENGTH(course_name), 0) = 0")
  256. .and(ObjectUtils.isNotEmpty(dto.getSemester()),
  257. wrapper -> wrapper
  258. .eq(BaseClassCourse::getBaseSemesterId, dto.getSemester())
  259. .or()
  260. .isNull(BaseClassCourse::getBaseSemesterId)
  261. )
  262. .and(wrapper -> wrapper
  263. .eq(BaseClassCourse::getDeleteMark, DeleteMark.NODELETE.getCode())
  264. .or()
  265. .isNull(BaseClassCourse::getDeleteMark)
  266. )
  267. .eq(BaseClass::getDeleteMark, DeleteMark.NODELETE.getCode())
  268. .orderByDesc(BaseCourseSubject::getName)
  269. .orderByDesc(Textbook::getBookName)
  270. ;
  271. List<ClassCourseTextbookExportQueryVo> dataList = baseClassMapper.selectJoinList(ClassCourseTextbookExportQueryVo.class, baseClassCourseMPJLambdaWrapper);
  272. // 根据班级分组
  273. Map<Long, List<ClassCourseTextbookExportQueryVo>> dataMapByClassId = dataList.stream()
  274. .collect(Collectors.groupingBy(
  275. ClassCourseTextbookExportQueryVo::getClassId,
  276. LinkedHashMap::new, // 指定使用LinkedHashMap来保持顺序
  277. Collectors.toList()
  278. ));
  279. List<Long> classIds = dataList.stream()
  280. .filter(c -> ObjectUtils.isNotEmpty(c.getClassId()))
  281. .map(ClassCourseTextbookExportQueryVo::getClassId)
  282. .collect(Collectors.toList());
  283. if(classIds.isEmpty()){
  284. throw new MyException("导出数据中班级有误,请刷新重试");
  285. }
  286. // 获取班级人数
  287. MPJLambdaWrapper<BaseStudentSchoolRoll> baseStudentSchoolRollMPJLambdaWrapper = new MPJLambdaWrapper<>();
  288. baseStudentSchoolRollMPJLambdaWrapper
  289. .selectAs(BaseStudentSchoolRoll::getClassId, BaseStudentSchoolRoll::getClassId)
  290. .selectCount(BaseStudentSchoolRoll::getId, BaseStudentSchoolRoll::getDeleteMark)
  291. .in(BaseStudentSchoolRoll::getClassId, classIds)
  292. .eq(BaseStudentSchoolRoll::getArchivesStatus, ArchivesStatusEnum.FB2901.getCode())
  293. .eq(BaseStudentSchoolRoll::getDeleteMark, DeleteMark.NODELETE.getCode())
  294. .groupBy(BaseStudentSchoolRoll::getClassId)
  295. ;
  296. List<BaseStudentSchoolRoll> baseStudentSchoolRolls = baseStudentSchoolRollMapper.selectJoinList(BaseStudentSchoolRoll.class, baseStudentSchoolRollMPJLambdaWrapper);
  297. Map<Long, Integer> stuNumMap = baseStudentSchoolRolls.stream()
  298. .collect(Collectors.toMap(BaseStudentSchoolRoll::getClassId, BaseStudentSchoolRoll::getDeleteMark, (k1,k2) -> k1));
  299. // 处理数据
  300. for (ClassCourseTextbookExportQueryVo c : dataList){
  301. // 处理使用学期
  302. if(ObjectUtils.isNotEmpty(c.getUseType())){
  303. String useType = UseSemesterTypeEnum.getValue(c.getUseType());
  304. c.setUseTypeCn(useType);
  305. }else {
  306. c.setUseTypeCn("未知");
  307. }
  308. // 处理班级人数
  309. Integer stuNum = stuNumMap.get(c.getClassId());
  310. if(ObjectUtils.isNotEmpty(stuNum)){
  311. c.setStudentNum(stuNum);
  312. // 处理总价
  313. if(ObjectUtils.isNotEmpty(c.getDiscountPrice())){
  314. BigDecimal totalPrices = c.getDiscountPrice().multiply(BigDecimal.valueOf(stuNum));
  315. c.setTotalPrices(totalPrices);
  316. }else {
  317. c.setTotalPrices(BigDecimal.ZERO);
  318. }
  319. }else {
  320. c.setStudentNum(0);
  321. }
  322. }
  323. // 开始写入
  324. Workbook workbook = new XSSFWorkbook();
  325. // 创建一个工作表(sheet)
  326. String sheetName = "sheet1";
  327. Sheet sheet = workbook.createSheet(sheetName);
  328. List<ImportConfig> importConfigs = allFields(new ClassCourseTextbookExportQueryVo());
  329. // 表头
  330. createHead(workbook, sheet, importConfigs, 0);
  331. // 内容
  332. int dataRowNumber = 1;
  333. Font font = workbook.createFont();
  334. font.setFontName("宋体");
  335. font.setFontHeightInPoints((short)12);
  336. CellStyle cellStyle = workbook.createCellStyle();
  337. cellStyle.setFont(font); // 将字体应用到样式
  338. cellStyle.setVerticalAlignment(VerticalAlignment.CENTER);
  339. cellStyle.setAlignment(HorizontalAlignment.CENTER);
  340. for (Map.Entry<Long, List<ClassCourseTextbookExportQueryVo>> entry : dataMapByClassId.entrySet()){
  341. Long key = entry.getKey();
  342. List<ClassCourseTextbookExportQueryVo> value = entry.getValue();
  343. List<List<String>> inList = new ArrayList<>();
  344. // 小计合计
  345. BigDecimal totalDiscountPrice = BigDecimal.ZERO;
  346. for (ClassCourseTextbookExportQueryVo c : value){
  347. totalDiscountPrice = totalDiscountPrice.add(ObjectUtils.isNotEmpty(c.getDiscountPrice()) ? c.getDiscountPrice() : BigDecimal.ZERO);
  348. }
  349. for (ClassCourseTextbookExportQueryVo c : value){
  350. c.setTotalDiscountPrice(totalDiscountPrice);
  351. }
  352. // 总价合计
  353. BigDecimal totalPriceTotal = BigDecimal.ZERO;
  354. for (ClassCourseTextbookExportQueryVo c : value){
  355. totalPriceTotal = totalPriceTotal.add(ObjectUtils.isNotEmpty(c.getTotalPrices()) ? c.getTotalPrices() : BigDecimal.ZERO);
  356. }
  357. for (ClassCourseTextbookExportQueryVo c : value){
  358. c.setTotalPriceTotal(totalPriceTotal);
  359. }
  360. // 开始写入
  361. for (ClassCourseTextbookExportQueryVo c : value){
  362. List<String> date = new ArrayList<>();
  363. date.add(c.getSemester());
  364. date.add(c.getDeptName());
  365. date.add(c.getClassName());
  366. date.add(c.getCourseName());
  367. date.add(c.getTextbookName());
  368. date.add(c.getUseTypeCn());
  369. date.add(c.getTextbookType());
  370. date.add(ObjectUtils.isNotEmpty(c.getPrice()) ? c.getPrice().toString() : "0");
  371. date.add(ObjectUtils.isNotEmpty(c.getDiscountPrice()) ? c.getDiscountPrice().toString() : "0");
  372. date.add(ObjectUtils.isNotEmpty(c.getTotalDiscountPrice()) ? c.getTotalDiscountPrice().toString() : "0");
  373. date.add(c.getStudentNum() + "");
  374. date.add(ObjectUtils.isNotEmpty(c.getTotalPrices()) ? c.getTotalPrices().toString() : "0");
  375. date.add(ObjectUtils.isNotEmpty(c.getTotalPriceTotal()) ? c.getTotalPriceTotal().toString() : "0");
  376. inList.add(date);
  377. }
  378. for (List<String> rowData : inList) {
  379. Row dataRow = sheet.createRow(dataRowNumber);
  380. for (int i = 0; i < rowData.size(); i++) {
  381. sheet.autoSizeColumn(i);
  382. Cell cell = dataRow.createCell(i);
  383. cell.setCellValue(rowData.get(i));
  384. cell.setCellStyle(cellStyle);
  385. }
  386. dataRowNumber++;
  387. }
  388. if(inList.size() > 1){
  389. sheet.addMergedRegion(new CellRangeAddress(dataRowNumber - inList.size(), dataRowNumber - 1, 9, 9));
  390. sheet.addMergedRegion(new CellRangeAddress(dataRowNumber - inList.size(), dataRowNumber - 1, 10, 10));
  391. sheet.addMergedRegion(new CellRangeAddress(dataRowNumber - inList.size(), dataRowNumber - 1, 12, 12));
  392. }
  393. }
  394. //写入文件
  395. ByteArrayOutputStream bot = new ByteArrayOutputStream();
  396. workbook.write(bot);
  397. return bot;
  398. }
  399. }