日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Java中EasyPoi導出復雜合并單元格的方法

瀏覽:26日期:2022-08-18 13:47:35
前言:

上星期做了一個Excel的單元格合并,用的是EasyPoi,我之前合并單元格都是原生的,第一次使用EasyPoi合并也不太熟悉,看著網上自己套用,使用后發現比原生的方便些,貢獻一下,也給其他用到合并而且用的是EasyPoi的小伙伴節省下時間。

導出模板:

Java中EasyPoi導出復雜合并單元格的方法

坐標:

版本號,自己來定,可以去官網查看:EasyPoi官網

<!-- easypoi 導入包 --> <dependency> <groupId>cn.afterturn</groupId> <artifactId>easypoi-base</artifactId> <version>4.0.0</version> </dependency> <dependency> <groupId>cn.afterturn</groupId> <artifactId>easypoi-annotation</artifactId> <version>4.0.0</version> </dependency>實現代碼:

//表頭設置List<ExcelExportEntity> colList = new ArrayList<ExcelExportEntity>();ExcelExportEntity colEntity = new ExcelExportEntity('經銷商', 'distributorName');colEntity.setNeedMerge(true);colEntity.setWidth(20);colList.add(colEntity);colEntity = new ExcelExportEntity('科室', 'dept');colEntity.setNeedMerge(true);colList.add(colEntity);colEntity = new ExcelExportEntity('部門', 'region');colEntity.setNeedMerge(true);colList.add(colEntity);colEntity = new ExcelExportEntity('省份', 'province');colEntity.setNeedMerge(true);colList.add(colEntity);colEntity = new ExcelExportEntity('門店數量', 'storeNum');colEntity.setNeedMerge(true);colEntity.setStatistics(true);colList.add(colEntity);Map<String, Integer> map = DateUtils.getLastDayOfMonthByStr(request.getMonthStr());Integer dayNum = map.get('dayNum');for (int i = 1; i <= dayNum; i++) { ExcelExportEntity group_1 = new ExcelExportEntity(i + '日', 'day'); List<ExcelExportEntity> exportEntities = new ArrayList<>(); ExcelExportEntity appalyExcel = new ExcelExportEntity('申請數量', 'applyNum' + i); appalyExcel.setStatistics(true); exportEntities.add(appalyExcel); ExcelExportEntity adoptExcel = new ExcelExportEntity('通過數量', 'adoptNum' + i); adoptExcel.setStatistics(true); exportEntities.add(adoptExcel); group_1.setList(exportEntities); colList.add(group_1);}//文件數據List<Map<String, Object>> list = new ArrayList<>();List<StoreNewAddReportVO.DistributorStoreNewAddReportVO> disList = register.getStoreNewAddReportVO().getDistributorStoreNewAddReportVOList();int size = disList.size();for (int i = 0; i < size; i++) { StoreNewAddReportVO.DistributorStoreNewAddReportVO dis = disList.get(i); Map<String, Object> valMap = new HashMap<>(); valMap.put('distributorName', dis.getDistributorName()); valMap.put('dept', dis.getDept()); valMap.put('region', dis.getRegion()); valMap.put('province', dis.getProvince()); valMap.put('storeNum', dis.getStoreNum()); List<StoreNewAddReportVO.dayData> dayDataList = dis.getDayDataList(); Map<String, List<StoreNewAddReportVO.dayData>> collectMap = Maps.newHashMap(); if (CollectionUtils.isNotEmpty(dayDataList)) { collectMap = dayDataList.stream().collect(Collectors.groupingBy(StoreNewAddReportVO.dayData::getDayStr)); } List<Map<String, Object>> list_1 = new ArrayList<>(); Map<String, Object> valMap_1 = new HashMap<>(); for (int j = 1; j <= dayNum; j++) { List<StoreNewAddReportVO.dayData> dayData = collectMap.get(String.valueOf(j)); int applyflag = 0; int adoptflag = 0; if (CollectionUtils.isNotEmpty(dayData)) { applyflag = dayData.get(0).getApplyNum(); adoptflag = dayData.get(0).getAdoptNum(); } valMap_1.put('applyNum' + j, applyflag); valMap_1.put('adoptNum' + j, adoptflag); } list_1.add(valMap_1); valMap.put('day', list_1); list.add(valMap);}//導出Workbook workbook = ExcelExportUtil.exportExcel(new ExportParams('【' + request.getMonthStr() + '】門店注冊日明細數據', '數據'), colList, list);Sheet sheet = workbook.getSheet('數據');Row row = sheet.getRow(sheet.getLastRowNum());Cell cell = row.getCell(0);cell.setCellValue('總計');CellStyle cellStyle = workbook.createCellStyle();cellStyle.setAlignment(HorizontalAlignment.CENTER);//水平居中cellStyle.setVerticalAlignment(VerticalAlignment.CENTER);//垂直居中Font font = workbook.createFont();font.setFontHeightInPoints((short) 15);font.setFontName('Trebuchet MS');cellStyle.setFont(font);cell.setCellStyle(cellStyle);CellRangeAddress range_0 = new CellRangeAddress(sheet.getLastRowNum(), sheet.getLastRowNum(), 0, 3);sheet.addMergedRegion(range_0);File file = new File('D:'.concat(UUID.randomUUID().toString().concat('.xls'))); FileOutputStream fileOutputStream = null; try { fileOutputStream = new FileOutputStream(file); workbook.write(fileOutputStream); } catch (Exception e) { log.error('門店注冊日workbook寫入到文件中失敗,錯誤信息:{}', ExceptionUtils.getStackTrace(e)); } finally { if (null != fileOutputStream) {try { fileOutputStream.close();} catch (IOException e) { //skip} } }

具體的API細節就不介紹了可以去官網,關鍵在于ExcelExportEntity 這個類,它是以map形式展現的,創建的時候設置key,設置value的根據key進行設置,上面一些StoreNewAddReportVO還有其他是我的業務類, 到時候可以替換掉。

到此這篇關于Java中EasyPoi導出復雜合并單元格的方法的文章就介紹到這了,更多相關Java EasyPoi導出單元格內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Java
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产精品男女| 麻豆精品av| 日本不卡免费高清视频在线| 麻豆国产欧美日韩综合精品二区| 中文一区二区| 午夜精品亚洲| 最新日韩欧美| 久久亚洲国产精品一区二区| 亚洲综合另类| 丝袜美腿一区二区三区| 玖玖玖国产精品| 亚洲一二av| 日韩精品中文字幕一区二区| 亚洲精选av| 日韩精品久久理论片| 日本成人在线一区| 欧美一区久久| 免费在线成人| 高清久久精品| 97人人精品| 精品久久精品| 欧美aa在线观看| 亚洲无线一线二线三线区别av| 久久精品av| 最新日韩欧美| 亚洲69av| 麻豆精品少妇| 日韩精品中文字幕第1页| 久久久精品日韩| 亚洲深夜影院| 日韩在线视频一区二区三区| 久久精品av麻豆的观看方式| 欧美激情在线精品一区二区三区| 国产不卡精品| 韩日一区二区三区| 亚洲欧洲另类| 日本一区二区三区中文字幕| 麻豆一区二区三| 日韩电影在线视频| 欧美日韩国产综合网| 免费观看在线色综合| 国产三级精品三级在线观看国产| 卡一精品卡二卡三网站乱码| 午夜欧美巨大性欧美巨大| 亚洲手机在线| 91成人精品在线| 国产成人精品亚洲线观看| 日韩高清中文字幕一区二区| 蜜臀av亚洲一区中文字幕| 国产精品v一区二区三区| 电影91久久久| 国产免费成人| 成人午夜国产| 日本成人精品| 日韩一区欧美| 亚洲欧美日韩综合国产aⅴ| 久久国产婷婷国产香蕉| 亚洲h色精品| 日韩精品免费观看视频| 日韩黄色大片| 欧美日一区二区在线观看| 日韩电影二区| 婷婷综合国产| 久久久一本精品| 欧美一级网站| 人人精品亚洲| 91成人小视频| 国产国产精品| 麻豆精品久久久| 亚洲一区二区网站| 牛牛精品成人免费视频| 午夜久久一区| 红杏一区二区三区| 男女性色大片免费观看一区二区| 国产精品毛片久久久| 99久久夜色精品国产亚洲1000部| 日本欧美大码aⅴ在线播放| 亚洲www啪成人一区二区| 欧美亚洲tv| 好看的av在线不卡观看| 欧美在线精品一区| 女人天堂亚洲aⅴ在线观看| 国产视频网站一区二区三区| 免费视频亚洲| 精品国产亚洲一区二区三区大结局| 国产亚洲在线观看| 国产成人精品福利| 88久久精品| 石原莉奈在线亚洲二区| 视频福利一区| 国内精品伊人| 国产精品一区二区av日韩在线| 亚洲欧美日韩精品一区二区 | 久久久久久美女精品| 国产日韩欧美在线播放不卡| 亚洲一区二区三区中文字幕在线观看| av综合电影网站| 国产精品1区| 欧美日韩亚洲一区在线观看| 久久亚洲美女| 亚洲二区免费| 欧美日韩国产观看视频| 精品一区91| 国产精品夜夜夜| 日韩久久99| 好看的亚洲午夜视频在线| 欧美aa在线观看| 精品美女在线视频| 国产精品尤物| 国产日韩欧美一区在线| 91精品麻豆| 欧美三区不卡| 欧美天堂在线| 日韩av网站在线免费观看| 综合亚洲视频| 亚洲开心激情| 亚洲欧美久久久| 亚洲在线网站| 免费精品视频在线| 亚洲乱码一区| 亚洲精品中文字幕99999| 亚洲视频电影在线| 综合激情网站| 亚洲精品一级二级三级| 日韩成人一级| 国产精品色在线网站| 精品三级av| 国产精品久久久久久久免费观看 | 精品不卡一区| 成人自拍av| 国产在线不卡| 久久福利一区| 日本在线不卡视频一二三区| 青青草精品视频| 日韩一区二区三区高清在线观看| 日韩欧美美女在线观看| 久久精品999| 精品免费视频| 久久一区二区三区喷水| 夜夜嗨一区二区三区| 日韩在线播放一区二区| 亚洲精品黄色| 精品一区电影| 欧美一区二区三区激情视频| 91久久午夜| 在线观看视频免费一区二区三区| 中文字幕日韩亚洲| 日本一区中文字幕| 国产欧美日韩在线一区二区| 国产精品17p| 欧美激情三区| 久久久噜噜噜| 一区二区三区午夜视频| 天堂va在线高清一区| 麻豆国产一区| av资源新版天堂在线| 欧美手机在线| 日韩视频中文| 69堂免费精品视频在线播放| 国产欧美综合一区二区三区| 红杏一区二区三区| 黄色aa久久| 99国产精品| 亚洲精品成人一区| 国产精品亚洲产品| 精品国产亚洲日本| av亚洲免费| 在线天堂中文资源最新版| 在线亚洲激情| 国产精品最新| av在线资源| 喷白浆一区二区| 日韩不卡一二三区| 欧美羞羞视频| 久久先锋影音| 国产精品久久国产愉拍| 欧美激情另类| 亚洲另类av| 国产精品极品在线观看| 人人精品亚洲| 视频一区中文字幕国产| 免费精品一区| 国产欧美三级| 九九综合九九| 久久99久久人婷婷精品综合| 日韩深夜视频| 日韩欧美久久| 久久精品免视看国产成人| 在线精品视频在线观看高清| 日本伊人午夜精品| 精品一区二区三区亚洲| 999视频精品| 日本v片在线高清不卡在线观看| 麻豆精品视频在线观看| 日韩欧美一区二区三区在线视频 | 在线亚洲欧美| 精品九九久久| 亚洲欧美日韩在线观看a三区| 精品一区二区三区亚洲| 99久久婷婷|