ApachePOI中关于SUMPRODUCT函数的一个问题:InvalidargtypeforSUMPRODUCT:(org.apache.poi.ss.formula.eval.ErrorEval)
创始人
2024-09-06 09:30:22
0

出现这个问题可能是因为SUMPRODUCT函数中的参数类型错误,其中可能包含了类型为ErrorEval的参数。这个问题可以通过将函数的参数进行类型检测和转换来解决。

以下示例代码演示了如何通过遍历函数参数列表并检查每个参数类型来解决这个问题:

int rowCount = sheet.getLastRowNum() + 1;
int columnCount = sheet.getRow(0).getLastCellNum();
int[] arrRow = new int[rowCount];
for (int i = 0; i < rowCount; i++) {
    arrRow[i] = i;
}

int[] arrCol = new int[columnCount];
for (int i = 0; i < columnCount; i++) {
    arrCol[i] = i;
}

// Create a formula evaluator
FormulaEvaluator evaluator = workbook.getCreationHelper().createFormulaEvaluator();

// Get the cell containing the SUMPRODUCT formula
CellReference formulaCellRef = new CellReference("B6");
Row formulaRow = sheet.getRow(formulaCellRef.getRow());
Cell formulaCell = formulaRow.getCell(formulaCellRef.getCol());

// Get the formula
String formula = formulaCell.getCellFormula();

// Parse the formula
PoiParser pp = new PoiParser(formula, workbook, evaluator, sheet);
pp.parse();

// Check the type of each argument and convert if necessary
for (int i = 0; i < pp.getArgs().length; i++) {
    PoiParser.ParsedExpression arg = pp.getArgs()[i];
    if (arg.isType(PoiParser.ExcelType.ERR)) {
        if (arg.getValue() instanceof ErrorEval) {
            // Convert ErrorEval to NullEval
            arg.setValue(BlankEval.instance);
        }
    }
}

// Evaluate the formula with the updated arguments
CellValue result = evaluator.evaluate(pp.getResult());
double value = result.getNumberValue();

在这个代码示例中,我们使用了PoiParser类来解析函数公式并获取函数参数。对于每个参数,我们使用isType()方法检查参数类型,如果类型为ErrorEval,则将其转换为BlankEval,然后再进行函数求值。这样就可以避免Invalid arg type for SUMPRODUCT: (org.apache.poi.ss.formula.eval.ErrorEval)这个问题。

相关内容

热门资讯

透视脚本!wepoker辅助器... 透视脚本!wepoker辅助器安装包,德普之星透视免费,详细教程(真是真的有挂);wepoker辅助...
透视辅助!hhpoker透视方... 透视辅助!hhpoker透视方法,pokermaster修改器,必赢教程(切实真的是有挂) 科技详细...
透视挂!智星德州菠萝插件官网,... 透视挂!智星德州菠萝插件官网,fishpoker透视,爆料教程(都是有挂);亲,其实确实真的有挂(需...
透视中牌率!德普之星透视辅助i... 透视中牌率!德普之星透视辅助ios,aapoker免费透视脚本,2025新版总结(原来真的有挂);精...
透视线上!wepoker底牌透... 1、透视线上!wepoker底牌透视脚本,wpk私人局辅助是真的吗,高科技教程(原本真的是有挂);详...
透视有挂!wepoker透视,... 这是一款非常优秀的wepoker透视 ia辅助检测软件,能够让你了解到wepoker透视中牌率当中全...
透视软件!智星德州菠萝插件官网... 1、透视软件!智星德州菠萝插件官网,hhpoker软件靠谱吗,软件教程(最初是真的有挂);详细教程。...
透视挂!德普之星app安卓版破... 透视挂!德普之星app安卓版破解版,如何下载wpk透视版,技巧教程(素来真的是有挂)需要回顾用户提供...
透视透视!aapoker辅助功... aapoker辅助功能赢率提升策略‌;透视透视!aapoker辅助功能,来玩德州破解器,规律教程(好...
透视游戏!wepoker底牌透... 透视游戏!wepoker底牌透视脚本,哈糖大菠萝开挂,技巧教程(一直是真的有挂)关于wepoker底...