İsimli Aralık için Formül Ayarlama C++ ile
Adlandırılmış Aralık için Formül Ayarlama
Excel uygulaması gibi, Aspose.Cells API’leri, GetRefersTo() özelliği kullanılırken, isimli aralıklar için bir formül belirleme yeteneği sağlar. Bu özelliğin birçok kullanım durumu vardır ve bazıları aşağıda detaylandırılmıştır.
Basit Formül Ayarlama Adlandırılmış Aralık için
Basit bir formül, aynı (veya farklı) çalışma sayfasındaki başka bir hücreye bir referans olabilir. Aşağıdaki örnek, yeni bir elektronik tablo oluşturur ve referansını başka bir hücreye ayarlar.
#include <iostream>
#include "Aspose.Cells.h"
using namespace Aspose::Cells;
int main()
{
Aspose::Cells::Startup();
// Source directory path
U16String srcDir(u"..\\Data\\01_SourceDirectory\\");
// Output directory path
U16String outDir(u"..\\Data\\02_OutputDirectory\\");
// Create an instance of Workbook
Workbook book;
// Get the WorksheetCollection
WorksheetCollection worksheets = book.GetWorksheets();
// Add a new Named Range with name "NewNamedRange"
int index = worksheets.GetNames().Add(u"NewNamedRange");
// Access the newly created Named Range
Name name = worksheets.GetNames().Get(index);
// Set RefersTo property of the Named Range to a formula. Formula references another cell in the same worksheet
name.SetRefersTo(u"=Sheet1!$A$3");
// Set the formula in the cell A1 to the newly created Named Range
worksheets.Get(0).GetCells().Get(u"A1").SetFormula(u"NewNamedRange");
// Insert the value in cell A3 which is being referenced in the Named Range
worksheets.Get(0).GetCells().Get(u"A3").PutValue(u"This is the value of A3");
// Calculate formulas
book.CalculateFormula();
// Save the result in XLSX format
book.Save(outDir + u"output_out.xlsx");
std::cout << "Named range created and formula calculated successfully!" << std::endl;
Aspose::Cells::Cleanup();
}
Karmaşık Formül Ayarlama Adlandırılmış Aralık için
Karmaşık bir formül, bir dinamik aralık veya farklı çalışma sayfalarındaki birden çok hücreye yayılan bir formül olabilir. Aşağıdaki örnek, bir değerin konumuna bağlı olarak INDEX işlevini kullanarak dinamik bir aralık oluşturur.
#include <iostream>
#include "Aspose.Cells.h"
using namespace Aspose::Cells;
int main()
{
Aspose::Cells::Startup();
// Source directory path
U16String srcDir(u"..\\Data\\01_SourceDirectory\\");
// Output directory path
U16String outDir(u"..\\Data\\02_OutputDirectory\\");
// Create an instance of Workbook
Workbook book;
// Get the WorksheetCollection
WorksheetCollection worksheets = book.GetWorksheets();
// Add a new Named Range with name "data"
int index = worksheets.GetNames().Add(u"data");
// Access the newly created Named Range from the collection
Name data = worksheets.GetNames().Get(index);
// Set RefersTo property of the Named Range to a cell range in same worksheet
data.SetRefersTo(u"=Sheet1!$A$1:$A$10");
// Add another Named Range with name "range"
index = worksheets.GetNames().Add(u"range");
// Access the newly created Named Range from the collection
Name range = worksheets.GetNames().Get(index);
// Set RefersTo property to a formula using the Named Range data
range.SetRefersTo(u"=INDEX(data,Sheet1!$A$1,1):INDEX(data,Sheet1!$A$1,9)");
// Save the workbook
book.Save(outDir + u"output_out.xlsx");
std::cout << "Named ranges created and workbook saved successfully!" << std::endl;
Aspose::Cells::Cleanup();
}
Aşağıda, farklı çalışma sayfalarındaki 2 hücreden değerleri toplamak için adlandırılmış bir aralık kullanan başka bir örnek bulunmaktadır.
#include <iostream>
#include "Aspose.Cells.h"
using namespace Aspose::Cells;
int main()
{
Aspose::Cells::Startup();
// Source directory path
U16String srcDir(u"..\\Data\\01_SourceDirectory\\");
// Output directory path
U16String outDir(u"..\\Data\\02_OutputDirectory\\");
// Create an instance of Workbook
Workbook book;
// Get the WorksheetCollection
WorksheetCollection worksheets = book.GetWorksheets();
// Insert some data in cell A1 of Sheet1
worksheets.Get(u"Sheet1").GetCells().Get(u"A1").PutValue(10);
// Add a new Worksheet and insert a value to cell A1
worksheets.Get(worksheets.Add()).GetCells().Get(u"A1").PutValue(10);
// Add a new Named Range with name "range"
int index = worksheets.GetNames().Add(u"range");
// Access the newly created Named Range from the collection
Name range = worksheets.GetNames().Get(index);
// Set RefersTo property of the Named Range to a SUM function
range.SetRefersTo(u"=SUM(Sheet1!$A$1,Sheet2!$A$1)");
// Insert the Named Range as formula to 3rd worksheet
worksheets.Get(worksheets.Add()).GetCells().Get(u"A1").SetFormula(u"range");
// Calculate formulas
book.CalculateFormula();
// Save the result in XLSX format
book.Save(outDir + u"output_out.xlsx");
std::cout << "Output file saved successfully!" << std::endl;
Aspose::Cells::Cleanup();
}