Çalışma Kitabının Formül Hesaplamasını Durdurun veya İptal Edin

Olası Kullanım Senaryoları

Aspose.Cells, çalışma kitabının formül hesaplamasını kesmek veya iptal etmek için bir mekanizma sağlar.AbstractCalculationMonitor.Interrupt()yöntem. Bu, çalışma kitabının formül hesaplaması çok zaman aldığında ve işlenmesini iptal etmek istediğinizde kullanışlıdır.

Çalışma Kitabının Formül Hesaplamasını Durdurun veya İptal Edin

Aşağıdaki örnek kod,Hesaplamadan Önce()yöntemiÖzetHesaplamaMonitör sınıf. Bu metot içerisinde satır ve sütun indeks parametrelerini kullanarak hücre adını bulur. Hücre adı B8 ise, hücreyi çağırarak hesaplama işlemini yarıda keser.AbstractCalculationMonitor.Interrupt()yöntem. Bir kez, somut sınıfÖzetHesaplamaMonitörsınıf uygulanır, örneği şuna atanır:CalculationOptions.CalculationMonitorEmlak. Nihayet,Workbook.CalculateFormula()geçerek denirHesaplama Seçenekleri parametre olarak. Lütfen bkzörnek excel dosyasıkodun içinde ve ayrıca referans olarak aşağıda verilen kodun konsol çıktısında kullanılır.

Basit kod

// For complete examples and data files, please go to https://github.com/aspose-cells/Aspose.Cells-for-.NET
class InterruptOrCancelFormulaCalculationOfWorkbook
{
//Implement calculation monitor class
class clsCalculationMonitor : AbstractCalculationMonitor
{
public override void BeforeCalculate(int sheetIndex, int rowIndex, int colIndex)
{
//Find the cell name
string cellName = CellsHelper.CellIndexToName(rowIndex, colIndex);
//Print the sheet, row and column index as well as cell name
System.Diagnostics.Debug.WriteLine(sheetIndex + "----" + rowIndex + "----" + colIndex + "----" + cellName);
//If cell name is B8, interrupt/cancel the formula calculation
if (cellName == "B8")
{
this.Interrupt("Interrupt/Cancel the formula calculation");
}//if
}//BeforeCalculate
}//clsCalculationMonitor
public static void Run()
{
//Load the sample Excel file
Workbook wb = new Workbook("sampleCalculationMonitor.xlsx");
//Create calculation options and assign instance of calculation monitor class
CalculationOptions opts = new CalculationOptions();
opts.CalculationMonitor = new clsCalculationMonitor();
//Calculate formula with calculation options
wb.CalculateFormula(opts);
}
}

Konsol Çıkışı

 0----1----3----D2

0----4----6----G5

0----7----1----B8