我正在使用 EPPlus 库来构建一个 excel 文件,并且想知道是否有办法使用这个库来检查公式中的循环引用?
我知道Microsoft Interop具有Range CircularReference { get; },但我试图避免使用它。
我正在使用 EPPlus 库来构建一个 excel 文件,并且想知道是否有办法使用这个库来检查公式中的循环引用?
我知道Microsoft Interop具有Range CircularReference { get; },但我试图避免使用它。
如果存在循环引用并且您不允许在计算选项中使用它,则在尝试计算时将引发异常。
顺便说一句,默认情况下循环引用会引发异常。允许他们将属性更改为 true。
您还可以计算整个工作表/工作簿。
检查单元格是否包含循环引用的示例代码:
//Assign Formula
var cell = worksheet.Cells["A2"]; //Example Cell
cell.Formula = "YourFormula";
//Initiate calculation option
var calculateOptions = new ExcelCalculationOption();
calculateOptions.AllowCirculareReferences = false;
bool isFormulaCircularReference = false;
try
{
cell.Calculate(calculateOptions);
}
catch (CircularReferenceException ex)
{
//If there is a circular reference this exception will be thrown
isFormulaCircularReference = true;
}