Newer
Older
ClosedXML / ClosedXML_Examples / Misc / CopyingRowsAndColumns.cs
@Amir Amir on 9 Sep 2016 4 KB Project hierarchy cleanup
using System;
using ClosedXML.Excel;


namespace ClosedXML_Examples.Misc
{
    public class CopyingRowsAndColumns : IXLExample
    {
        #region Variables

        // Public

        // Private


        #endregion

        #region Properties

        // Public

        // Private

        // Override


        #endregion

        #region Events

        // Public

        // Private

        // Override


        #endregion

        #region Methods

        // Public
        public void Create(String filePath)
        {
            var workbook = new XLWorkbook();

            var originalSheet = workbook.Worksheets.Add("original");

            originalSheet.Cell("A2").SetValue("test value");
            originalSheet.Range("A2:E2").Merge();

            originalSheet.Cell("F1").SetValue("test value").Style.Alignment.SetTopToBottom();
            originalSheet.Range("F1:F6").Merge();

            var fromRow = workbook.Worksheets.Add("From a Row");
            fromRow.Cell(1, 1).SetValue("Row to Row:");
            originalSheet.Row(2).CopyTo(fromRow.Row(2));
            fromRow.Cell(3, 1).SetValue("Row to Range:");
            originalSheet.Row(2).CopyTo(fromRow.Row(4).AsRange());
            fromRow.Cell(5, 1).SetValue("Row to Cell:");
            originalSheet.Row(2).CopyTo(fromRow.Row(6).FirstCell());

            var fromRange = workbook.Worksheets.Add("From a Range");
            fromRange.Cell(1, 1).SetValue("Range to Row:");
            originalSheet.Row(2).AsRange().CopyTo(fromRange.Row(2));
            fromRange.Cell(3, 1).SetValue("Range to Range:");
            originalSheet.Row(2).AsRange().CopyTo(fromRange.Row(4).AsRange());
            fromRange.Cell(5, 1).SetValue("Range to Cell:");
            originalSheet.Row(2).AsRange().CopyTo(fromRange.Row(6).FirstCell());

            CopyRowAsRange(originalSheet, 2, fromRange, 8);

            var fromColumn = workbook.Worksheets.Add("From a Column to Column");
            fromColumn.Cell(1, 1).SetValue("Column to Column:").Style.Alignment.SetTopToBottom();
            originalSheet.Column("F").CopyTo(fromColumn.Column(2));
            fromColumn.Cell(1, 3).SetValue("Column to Range:").Style.Alignment.SetTopToBottom();
            originalSheet.Column("F").CopyTo(fromColumn.Column(4).AsRange());
            fromColumn.Cell(1, 5).SetValue("Column to Cell:").Style.Alignment.SetTopToBottom();
            originalSheet.Column("F").CopyTo(fromColumn.Column(6).FirstCell());

            var fromRangeToColumn = workbook.Worksheets.Add("From a Range to Column");
            fromRangeToColumn.Cell(1, 1).SetValue("Range to Column:").Style.Alignment.SetTopToBottom();
            originalSheet.Column("F").AsRange().CopyTo(fromRangeToColumn.Column(2));
            fromRangeToColumn.Cell(1, 3).SetValue("Range to Range:").Style.Alignment.SetTopToBottom();
            originalSheet.Column("F").AsRange().CopyTo(fromRangeToColumn.Column(4).AsRange());
            fromRangeToColumn.Cell(1, 5).SetValue("Range to Cell:").Style.Alignment.SetTopToBottom();
            originalSheet.Column("F").AsRange().CopyTo(fromRangeToColumn.Column(6).FirstCell());
          

            workbook.SaveAs(filePath);
        }

        private static void CopyRowAsRange(IXLWorksheet originalSheet, int originalRowNumber, IXLWorksheet destSheet, int destRowNumber)
        {
            {
                var destinationRow = destSheet.Row(destRowNumber);
                destinationRow.Clear();

                var originalRow = originalSheet.Row(originalRowNumber);
                int columnNumber = originalRow.LastCellUsed(true).Address.ColumnNumber;

                var originalRange = originalSheet.Range(originalRowNumber, 1, originalRowNumber, columnNumber);
                var destRange = destSheet.Range(destRowNumber, 1, destRowNumber, columnNumber);
                originalRange.CopyTo(destRange);
            }
        }
        // Private

        // Override


        #endregion
    }
}