aboutsummaryrefslogtreecommitdiff
path: root/RhSolutions.ExcelExtensions/Column.cs
diff options
context:
space:
mode:
authorSergey Chebotar <s.chebotar@gmail.com>2023-04-01 15:58:42 +0300
committerSergey Chebotar <s.chebotar@gmail.com>2023-04-01 15:58:42 +0300
commit448af8ecd7bf9db070e090c4b434da693ba0ae89 (patch)
treead9a06664be368ebead54b82a965aa86f0a23cca /RhSolutions.ExcelExtensions/Column.cs
parentda29243d1d661a6e304018e3317c2ca4ea495db8 (diff)
Move Excel extensions to own project
Diffstat (limited to 'RhSolutions.ExcelExtensions/Column.cs')
-rw-r--r--RhSolutions.ExcelExtensions/Column.cs47
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];
+ }
+}