Copy Row Heights of Source Range to Destination Range with C++
Contents
[
Hide
]
Sometimes, users need to copy row heights from a source range to a destination range. Aspose.Cells provides the PasteType::RowHeights enum for this purpose. When you set the GetPasteType() property with the PasteType::RowHeights enum, the heights of all rows inside the source range will be copied to the destination range.
The following sample code explains how to use the PasteType::RowHeights enum to copy row heights from a source range into a destination range. Once you open the output Excel file generated by this code in Microsoft Excel, you will see that the destination range row heights are exactly the same as the source range row heights.
#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 workbook object
Workbook workbook;
// Source worksheet
Worksheet srcSheet = workbook.GetWorksheets().Get(0);
// Add destination worksheet
Worksheet dstSheet = workbook.GetWorksheets().Add(u"Destination Sheet");
// Set the row height of the 4th row. This row height will be copied to destination range
srcSheet.GetCells().SetRowHeight(3, 50);
// Create source range to be copied
Range srcRange = srcSheet.GetCells().CreateRange(u"A1:D10");
// Create destination range in destination worksheet
Range dstRange = dstSheet.GetCells().CreateRange(u"A1:D10");
// PasteOptions, we want to copy row heights of source range to destination range
PasteOptions opts;
opts.SetPasteType(PasteType::RowHeights);
// Copy source range to destination range with paste options
dstRange.Copy(srcRange, opts);
// Write informative message in cell D4 of destination worksheet
dstSheet.GetCells().Get(u"D4").PutValue(u"Row heights of source range copied to destination range");
// Save the workbook in xlsx format
workbook.Save(outDir + u"output_out.xlsx", SaveFormat::Xlsx);
std::cout << "Row heights copied successfully!" << std::endl;
Aspose::Cells::Cleanup();
}