JAVA合并Excel,把多个Excel合并成一个Excel,合并内容仅包括文字,图片

本文介绍如何使用Java编程语言将多个包含纯文字内容的Excel文件合并成一个Excel文件,不涉及图片数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 


package lotus;

import org.apache.poi.POIXMLDocumentPart;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.CellStyle;
import org.apache.poi.ss.usermodel.CellType;
import org.apache.poi.ss.usermodel.DateUtil;
import org.apache.poi.ss.usermodel.FillPatternType;
import org.apache.poi.ss.usermodel.IndexedColors;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.util.CellRangeAddress;
import org.apache.poi.xssf.usermodel.XSSFCell;
import org.apache.poi.xssf.usermodel.XSSFCellStyle;
import org.apache.poi.xssf.usermodel.XSSFClientAnchor;
import org.apache.poi.xssf.usermodel.XSSFDrawing;
import org.apache.poi.xssf.usermodel.XSSFPicture;
import org.apache.poi.xssf.usermodel.XSSFPictureData;
import org.apache.poi.xssf.usermodel.XSSFRow;
import org.apache.poi.xssf.usermodel.XSSFShape;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import org.openxmlformats.schemas.drawingml.x2006.spreadsheetDrawing.CTMarker;

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;

public class MergeExcel2007X {

    /**
     * #合并多个excel文件
     *
     * @param filePath excel文件路径
     * @param path     目标文件保存目录
     * @param fileName 目标文件名称 path2, path, fileName, c1,r1,x1, y1, c2,r2, x2,y2
     *
     *                 public static void mergeExcel(String filePath, String path,
     *                 String fileName, int dx12, int dy12, int dx22,int dy22) {
     */
    public void mergeExcel(String filePath, String path, String fileName, boolean config, int c1, int r1, int x1,
            int y1, int c2, int r2, int x2, int y2) {

        List<String> fileLists = getFilePathList(filePath);
        // 创建新的excel工作簿
        XSSFWorkbook newExcelWorkBook = new XSSFWorkbook();
        // 遍历需要合并的excel文件
        for (String excelName : fileLists) {
            File file = new File(excelName);
            try (InputStream in = new FileInputStream(excelName)) {
                // 创建工作簿
                XSSFWorkbook tmpWorkBook = new XSSFWorkbook(in);
                // 获取工作簿中的Sheet个数
                int len = tmpWorkBook.getNumberOfSheets();
                if (len <= 1) {
                    XSSFSheet tmpSheet = tmpWorkBook.getSheetAt(0);
                    // XSSFSheet newExcelSheet =
                    // newExcelWorkBook.createSheet(tmpSheet.getSheetName() + Math.random());
                    XSSFSheet newExcelSheet = newExcelWorkBook
                            .createSheet(file.getName().substring(0, file.getName().lastIndexOf(".")));
                    // 复制sheet内容
                    copyExcelSheet(newExcelWorkBook, tmpSheet, newExcelSheet);
                    copyPicture(newExcelWorkBook, tmpSheet, newExcelSheet, config, c1, r1, x1, y1, c2, r2, x2, y2);
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值