Apache Poi 的 Excel(.xlsx)文件已损坏。(使用 XSSF)
创始人
2024-09-04 15:30:42
0

以下是一种解决方法,使用Apache POI库的XSSF来处理损坏的.xlsx文件:

import org.apache.poi.openxml4j.exceptions.InvalidFormatException;
import org.apache.poi.ss.usermodel.*;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;

public class ExcelFileRepair {
    public static void main(String[] args) {
        String filePath = "path/to/your/file.xlsx";

        try {
            FileInputStream fis = new FileInputStream(new File(filePath));
            Workbook workbook = WorkbookFactory.create(fis);

            // 修复损坏的文件
            if (workbook instanceof XSSFWorkbook) {
                XSSFForceFormulaRecalculation recalculation = new XSSFForceFormulaRecalculation((XSSFWorkbook) workbook);
                recalculation.forceFormulaRecalculation();
            }

            // 处理工作表
            for (int i = 0; i < workbook.getNumberOfSheets(); i++) {
                Sheet sheet = workbook.getSheetAt(i);

                for (Row row : sheet) {
                    for (Cell cell : row) {
                        // 处理单元格数据
                        CellType cellType = cell.getCellType();

                        if (cellType == CellType.FORMULA) {
                            // 重新计算公式
                            CellValue cellValue = CellEvaluator.evaluateFormula(cell, workbook);
                            cell.setCellValue(cellValue.getNumberValue());
                        }
                    }
                }
            }

            // 保存修复后的文件
            workbook.setForceFormulaRecalculation(true);
            workbook.write(new File("path/to/save/fixedfile.xlsx"));
            workbook.close();

            System.out.println("修复成功并保存修复后的文件。");
        } catch (IOException | InvalidFormatException e) {
            e.printStackTrace();
        }
    }
}

请确保将path/to/your/file.xlsx替换为要修复的.xlsx文件的实际路径。修复后的文件将保存为path/to/save/fixedfile.xlsx

此代码示例使用Apache POI库的XSSFForceFormulaRecalculation类来强制重新计算.xlsx文件中的公式。然后,通过遍历工作表和单元格,重新计算并修复所有单元格中的公式。最后,修复的文件将保存在指定的路径中。

相关内容

热门资讯

透视安卓版!wepoker辅助... 透视安卓版!wepoker辅助下载,werplan外卦神器,可靠教程(素来存在有挂);科技安装教程;...
透视存在!wepoker透视脚... 透视存在!wepoker透视脚本免费下载,pokeplus脚本,我来教教你(原来存在有挂);wepo...
透视讲解!wepoker作弊辅... 透视讲解!wepoker作弊辅助,aapoker透视脚本,透明挂教程(果然真的有挂);亲,其实确实真...
辅助透视!德普之星有没有挂,w... 辅助透视!德普之星有没有挂,wepoker透视脚本苹果版,2025新版总结(果然是真的有挂)科技教程...
透视软件!wpk透视表,约局吧... 透视软件!wpk透视表,约局吧开挂神器是真的吗,曝光教程(都是存在有挂);人气非常高,ai更新快且高...
透视挂透视!智星德州菠萝透视插... 透视挂透视!智星德州菠萝透视插件工具,德普辅助器辅助器怎么用,德州论坛(本然是真的有挂);大神普及一...
透视系统!aapoker辅助插... 透视系统!aapoker辅助插件工具,aapoker透视脚本,力荐教程(果然是真的有挂);原来确实真...
透视攻略!hhpoker透视方... 透视攻略!hhpoker透视方法,aapoker免费透视脚本,透明挂教程(真是有挂);最新版2024...
透视数据!aapoker可以开... 透视数据!aapoker可以开挂吗,wepoker透视脚本是什么,普及教程(从前有挂);《WPK辅助...
透视辅助!aapoker辅助插... 1、透视辅助!aapoker辅助插件工具,德普之星辅助软件,可靠教程(原先真的是有挂);详细教程。2...