日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

Java poi插件导出Excel文件合并多sheet页

發(fā)布時間:2025/1/21 java 48 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Java poi插件导出Excel文件合并多sheet页 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

文章目錄

    • 一、java導(dǎo)出excel格式文件
    • 二、excel文件多sheet頁合并

前言:2020年第一篇文章,就寫這兩天工作中遇到的這個小需求吧,導(dǎo)出多excel,每個excel有多個sheet頁,需要把相同格式的excel的sheet頁合并。2020年寫出更優(yōu)質(zhì)的文章,讓大家都能從中學到更多的知識。

一、java導(dǎo)出excel格式文件

java導(dǎo)出excel文件,有一個比較好的開源框架,比較好用,而且使用也非常簡單,我們不必重復(fù)造輪子。

GitHub地址為:Excel4J

使用的時候可以直接引用pom文件

<dependency><groupId>com.github.crab2died</groupId><artifactId>Excel4J</artifactId><version>3.0.0-Alpha</version> </dependency>

舉個簡單例子:把要導(dǎo)出的對象組裝成list,直接一行代碼就可以搞定

ExcelUtils.getInstance().exportObjects2Excel(list2, header, "D:/D.xlsx");

更多具體例子可以參考:GitHub地址為:Excel4J 上面例子。

二、excel文件多sheet頁合并

有時候我們會遇到類似這樣的需求,比如excel文件多sheet頁合并,當遇到這樣的需求的時候,首先我們poi的API必需要熟悉。例如:如何創(chuàng)建sheet,如何創(chuàng)建sheet頁里面的行,如何給sheet頁里面的單元格賦值。

  • 創(chuàng)建工作簿
Workbook megreWorkbook = new XSSFWorkbook(); (2007版excel)
  • 獲取工作表中的sheet頁
Sheet sheetAt = book.getSheetAt(i);
  • 創(chuàng)建新的sheet
Sheet sheet = megreWorkbook.createSheet(workbook.getSheetName(i));
  • 創(chuàng)建sheet頁里面的行
Row megreRow = sheet.createRow(k);
  • 給sheet頁里面的單元格賦值
Cell cell = row.getCell(h);megreRow.createCell(h).setCellValue(getCellValue(cell));

主要核心代碼如下

public static void megreSheet() throws Exception {Workbook megreWorkbook = null;try {megreWorkbook = new XSSFWorkbook();int k = 0;//循環(huán)讀取每個excel文件List<Workbook> list = new ArrayList<>();InputStream inputStream = new FileInputStream(new File("D:\\aplus\\shuqian\\megre\\額度明細報表.xlsx"));Workbook workbook = new XSSFWorkbook(inputStream);list.add(workbook);InputStream inputStream1 = new FileInputStream(new File("D:\\aplus\\shuqian\\megre\\額度明細報表1.xlsx"));Workbook workbook1 = new XSSFWorkbook(inputStream1);list.add(workbook1);int numberOfSheets = workbook.getNumberOfSheets();for (int i = 0;i < numberOfSheets; i++) {Sheet sheet = megreWorkbook.createSheet(workbook.getSheetName(i));for (Workbook book:list) {Sheet sheetAt = book.getSheetAt(i);for (int j = 0; j < sheetAt.getLastRowNum() + 1;j++) {// 只針對第一個excel文件才讀取表頭,其余文件將不再讀取表頭if (k > 0 && j ==0) {continue;}Row megreRow = sheet.createRow(k);Row row = sheetAt.getRow(j);//讀取for (int h = 0;h < row.getPhysicalNumberOfCells(); h++) {Cell cell = row.getCell(h);megreRow.createCell(h).setCellValue(getCellValue(cell));}k++;}}k = 0;}OutputStream outputStream = new FileOutputStream("D:\\aplus\\shuqian\\megre\\額度明細報表Ex.xlsx");megreWorkbook.write(outputStream);}finally {if (megreWorkbook != null) {megreWorkbook.close();}}} public static String getCellValue(Cell c) {String o;switch (c.getCellTypeEnum()) {case BLANK:o = "";break;case BOOLEAN:o = String.valueOf(c.getBooleanCellValue());break;case FORMULA:o = calculationFormula(c);break;case NUMERIC:if (DateUtil.isCellDateFormatted(c)) {o = DateUtils.date2Str(c.getDateCellValue());} else {o = String.valueOf(c.getNumericCellValue());o = matchDoneBigDecimal(o);o = RegularUtils.converNumByReg(o);}break;case STRING:o = c.getStringCellValue();break;default:o = null;break;}return o;}

測試使用excel文件格式為:

以上就是關(guān)于excel文件sheet頁合并主要方法,祝大家在新的一年里面心想事成。

總結(jié)

以上是生活随笔為你收集整理的Java poi插件导出Excel文件合并多sheet页的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。