Excel合并记录

前天,被产品经理要求我将原本二十多个excel合并成一个excel,合并后的一个excel大概30W+左右的数据量,于是我使用poi对excel进行合并,我直接贴代码。实验数据大概15W左右,耗时大概35秒


 

合并excel代码

public static void mergeExcel(String path, String outputPath) throws IOException {
        //1.校验文件是否符合要求
        File targetFile = new File(path);

        if (!targetFile.exists() || !targetFile.isDirectory()) {
            LOGGER.info("文件不存在或者文件不是文件夹");
            return;
        }

        File[] files = targetFile.listFiles(p -> p.getName().endsWith(".xlsx"));
        if (files == null || files.length <= 0) {
            LOGGER.info("文件夹没有excel文件");
            return;
        }

        String startTime = DateUtil.getCurrentTimeStr();
        //2.数据合并
        //目前默认只合并第一个sheet,对于第一个excel文件,所有数据皆写入,对于后面的excel,从第二行数据开始拿起
        int sourceValidRows = 0;
        SXSSFWorkbook srcSXSSWb = null;
        for (int i = 0; i < files.length; i++) {
            if (i == 0) {
                InputStream is = new FileInputStream(files[i]);
                XSSFWorkbook headXssfWb = new XSSFWorkbook(is);
                XSSFSheet sourceSheet = headXssfWb.getSheetAt(DEFAULT_SHEEET_INDEX);
                sourceValidRows = sourceSheet.getPhysicalNumberOfRows();
                //3.写入新文件
                srcSXSSWb = new SXSSFWorkbook(headXssfWb);
            } else {
                InputStream is = new FileInputStream(files[i]);
                XSSFWorkbook targetXssfWb = new XSSFWorkbook(is);
                SXSSFSheet sourceSheet = srcSXSSWb.getSheetAt(DEFAULT_SHEEET_INDEX);
                XSSFSheet targetSheet = targetXssfWb.getSheetAt(DEFAULT_SHEEET_INDEX);
                for (int targetSheetRow = 1; targetSheetRow < targetSheet.getPhysicalNumberOfRows(); targetSheetRow++) {
                    LOGGER.info(i + "--" + targetSheetRow + " | sourceValidRows -- " + (sourceValidRows + targetSheetRow));
                    XSSFRow targetRow = targetSheet.getRow(targetSheetRow);
                    SXSSFRow sourceRow = sourceSheet.createRow(sourceValidRows + targetSheetRow);
                    for (int cellIndex = 0; cellIndex < targetRow.getPhysicalNumberOfCells(); cellIndex++) {
                        XSSFCell targetCell = targetRow.getCell(cellIndex);
                        SXSSFCell sourceCell = sourceRow.createCell(cellIndex);
                        sourceCell.setCellValue(targetCell.getStringCellValue());
                    }
                }
                sourceValidRows = sourceValidRows + targetSheet.getPhysicalNumberOfRows();
                LOGGER.info("有效行数:" + sourceSheet.getPhysicalNumberOfRows());
                is.close();
                targetXssfWb.close();
            }
        }
        //3.写入新文件
        FileOutputStream out = new FileOutputStream(outputPath);
        srcSXSSWb.write(out);
        out.close();

        srcSXSSWb.dispose();
        LOGGER.info("开始时间:" + startTime + ",结束时间:" + DateUtil.getCurrentTimeStr());

    }

main方法

public static void main(String[] args) {
        try {
            mergeExcel("C:/Users/xxx/Desktop/asd", "C:/Users/xxx/Desktop/ae.xlsx");
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
要在C#中使用Microsoft.Office.Interop.Excel库来合并Excel单元格,可以按照以下步骤进行操作: 首先,需要创建一个Excel应用程序对象和一个工作簿对象。可以使用以下代码创建它们: ``` Microsoft.Office.Interop.Excel.Application xlApp = new Microsoft.Office.Interop.Excel.Application(); Microsoft.Office.Interop.Excel.Workbook myWorkbook = xlApp.Workbooks.Open(savePath); ``` 然后,获取活动工作表并确定要操作的单元格范围。可以使用以下代码获取工作表和记录的行数: ``` Microsoft.Office.Interop.Excel.Worksheet mySheet = myWorkbook.ActiveSheet; int excelCount = mySheet.UsedRange.CurrentRegion.Rows.Count; ``` 接下来,可以调用合并单元格的函数来实现单元格的合并。可以使用以下代码来合并A列和B列的单元格: ``` MergeCell(ref mySheet, 1, excelCount, "A"); MergeCell(ref mySheet, 1, excelCount, "B"); ``` 最后,为了避免弹出保存和覆盖的提示框,可以将DisplayAlerts和AlertBeforeOverwriting属性设置为false: ``` xlApp.DisplayAlerts = false; xlApp.AlertBeforeOverwriting = false; ``` 请注意,上述代码中的MergeCell函数是自定义的函数,用于实际执行单元格合并的操作。您需要根据自己的需求来实现这个函数。 以上是在C#中使用Microsoft.Office.Interop.Excel合并Excel单元格的步骤。希望对您有所帮助! <span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [C#中Excel单元格合并](https://blog.csdn.net/jiangzhaobao/article/details/7963130)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [C#合并Excel单元格](https://blog.csdn.net/Andrewniu/article/details/89416680)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值