diff options
author | Sergey Chebotar <s.chebotar@gmail.com> | 2023-04-01 15:58:42 +0300 |
---|---|---|
committer | Sergey Chebotar <s.chebotar@gmail.com> | 2023-04-01 15:58:42 +0300 |
commit | 448af8ecd7bf9db070e090c4b434da693ba0ae89 (patch) | |
tree | ad9a06664be368ebead54b82a965aa86f0a23cca /RhSolutions.ExcelExtensions/Column.cs | |
parent | da29243d1d661a6e304018e3317c2ca4ea495db8 (diff) |
Move Excel extensions to own project
Diffstat (limited to 'RhSolutions.ExcelExtensions/Column.cs')
-rw-r--r-- | RhSolutions.ExcelExtensions/Column.cs | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/RhSolutions.ExcelExtensions/Column.cs b/RhSolutions.ExcelExtensions/Column.cs new file mode 100644 index 0000000..53a1f3d --- /dev/null +++ b/RhSolutions.ExcelExtensions/Column.cs @@ -0,0 +1,47 @@ +using System.Collections; + +namespace RhSolutions.ExcelExtensions; + +public sealed class Column : Table, IEnumerable<TableCell> +{ + public string Header + { + get => Range.Cells[1, 1].Value.ToString(); + } + public int Index + { + get => Range.Column - ParentTable.Range.Column; + } + public int Length + { + get => Range.Rows.Count; + } + + public Column(Range range, Table table) : base(range, table) + { + Range = range; + ParentTable = table; + } + + public TableCell this[int index] + { + get => new(Range.Cells[index + 1, 1], ParentTable); + } + + public IEnumerator<TableCell> GetEnumerator() + { + return new ColumnEnumerator(Range, ParentTable); + } + + IEnumerator IEnumerable.GetEnumerator() => GetEnumerator(); + + + public Column AddLeft() + { + Range.EntireColumn + .Insert(XlInsertShiftDirection.xlShiftToRight, + XlInsertFormatOrigin.xlFormatFromRightOrBelow); + + return ParentTable.Columns[this.Index - 1]; + } +} |