aboutsummaryrefslogtreecommitdiff
path: root/RhSolutions.ExcelExtensions/Columns.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/Columns.cs
parentda29243d1d661a6e304018e3317c2ca4ea495db8 (diff)
Move Excel extensions to own project
Diffstat (limited to 'RhSolutions.ExcelExtensions/Columns.cs')
-rw-r--r--RhSolutions.ExcelExtensions/Columns.cs39
1 files changed, 39 insertions, 0 deletions
diff --git a/RhSolutions.ExcelExtensions/Columns.cs b/RhSolutions.ExcelExtensions/Columns.cs
new file mode 100644
index 0000000..1fbc0ef
--- /dev/null
+++ b/RhSolutions.ExcelExtensions/Columns.cs
@@ -0,0 +1,39 @@
+using System.Collections;
+
+namespace RhSolutions.ExcelExtensions;
+
+public class Columns : IEnumerable<Column>
+{
+ public Range Range { get; }
+ public Table ParentTable { get; }
+ public int Length
+ {
+ get => Range.Columns.Count;
+ }
+
+ public Columns(Range range, Table parentTable)
+ {
+ Range = range;
+ ParentTable = parentTable;
+ }
+
+ public Column this[int index]
+ {
+ get
+ {
+ if (index < 0 || index + 1 > Range.Columns.Count)
+ {
+ throw new IndexOutOfRangeException();
+ }
+
+ return new Column(Range.Columns[index + 1], ParentTable);
+ }
+ }
+
+ public IEnumerator<Column> GetEnumerator()
+ {
+ return new ColumnsEnumerator(Range, ParentTable);
+ }
+
+ IEnumerator IEnumerable.GetEnumerator() => GetEnumerator();
+} \ No newline at end of file