public void ConsolidateRangesSameWorksheet() { var wb = new XLWorkbook(); var ws = wb.Worksheets.Add("Sheet1"); var ranges = new XLRanges(); ranges.Add(ws.Range("A1:E3")); ranges.Add(ws.Range("A4:B10")); ranges.Add(ws.Range("E2:F12")); ranges.Add(ws.Range("C6:I8")); ranges.Add(ws.Range("G9:G9")); ranges.Add(ws.Range("C9:D9")); ranges.Add(ws.Range("H9:H9")); ranges.Add(ws.Range("I9:I13")); ranges.Add(ws.Range("C4:D5")); var consRanges = ranges.Consolidate().ToList(); Assert.AreEqual(6, consRanges.Count); Assert.AreEqual("A1:E9", consRanges[0].RangeAddress.ToString()); Assert.AreEqual("F2:F12", consRanges[1].RangeAddress.ToString()); Assert.AreEqual("G6:I9", consRanges[2].RangeAddress.ToString()); Assert.AreEqual("A10:B10", consRanges[3].RangeAddress.ToString()); Assert.AreEqual("E10:E12", consRanges[4].RangeAddress.ToString()); Assert.AreEqual("I10:I13", consRanges[5].RangeAddress.ToString()); }
public void ConsolidateRangesDifferentWorksheets() { var wb = new XLWorkbook(); var ws1 = wb.Worksheets.Add("Sheet1"); var ws2 = wb.Worksheets.Add("Sheet2"); var ranges = new XLRanges(); ranges.Add(ws1.Range("A1:E3")); ranges.Add(ws1.Range("A4:B10")); ranges.Add(ws1.Range("E2:F12")); ranges.Add(ws1.Range("C6:I8")); ranges.Add(ws1.Range("G9:G9")); ranges.Add(ws2.Row(5)); ranges.Add(ws2.Row(7)); ranges.Add(ws2.Row(6)); ranges.Add(ws2.Column("D")); ranges.Add(ws2.Column("F")); ranges.Add(ws2.Column("E")); ranges.Add(ws1.Range("C9:D9")); ranges.Add(ws1.Range("H9:H9")); ranges.Add(ws1.Range("I9:I13")); ranges.Add(ws1.Range("C4:D5")); var consRanges = ranges.Consolidate() .OrderBy(r => r.Worksheet.Name) .ThenBy(r => r.RangeAddress.FirstAddress.RowNumber) .ThenBy(r => r.RangeAddress.FirstAddress.ColumnNumber) .ToList(); Assert.AreEqual(9, consRanges.Count); Assert.AreEqual("Sheet1!$A$1:$E$9", consRanges[0].RangeAddress.ToStringFixed(XLReferenceStyle.Default, true)); Assert.AreEqual("Sheet1!$F$2:$F$12", consRanges[1].RangeAddress.ToStringFixed(XLReferenceStyle.Default, true)); Assert.AreEqual("Sheet1!$G$6:$I$9", consRanges[2].RangeAddress.ToStringFixed(XLReferenceStyle.Default, true)); Assert.AreEqual("Sheet1!$A$10:$B$10", consRanges[3].RangeAddress.ToStringFixed(XLReferenceStyle.Default, true)); Assert.AreEqual("Sheet1!$E$10:$E$12", consRanges[4].RangeAddress.ToStringFixed(XLReferenceStyle.Default, true)); Assert.AreEqual("Sheet1!$I$10:$I$13", consRanges[5].RangeAddress.ToStringFixed(XLReferenceStyle.Default, true)); Assert.AreEqual("Sheet2!$D:$F", consRanges[6].RangeAddress.ToStringFixed(XLReferenceStyle.Default, true)); Assert.AreEqual("Sheet2!$A$5:$C$7", consRanges[7].RangeAddress.ToStringFixed(XLReferenceStyle.Default, true)); Assert.AreEqual("Sheet2!$G$5:$XFD$7", consRanges[8].RangeAddress.ToStringFixed(XLReferenceStyle.Default, true)); }
public void ConsolidateSparsedRanges() { var wb = new XLWorkbook(); var ws = wb.Worksheets.Add("Sheet1"); var ranges = new XLRanges(); ranges.Add(ws.Range("A1:C1")); ranges.Add(ws.Range("E1:G1")); ranges.Add(ws.Range("A3:C3")); ranges.Add(ws.Range("E3:G3")); var consRanges = ranges.Consolidate().ToList(); Assert.AreEqual(4, consRanges.Count); Assert.AreEqual("A1:C1", consRanges[0].RangeAddress.ToString()); Assert.AreEqual("E1:G1", consRanges[1].RangeAddress.ToString()); Assert.AreEqual("A3:C3", consRanges[2].RangeAddress.ToString()); Assert.AreEqual("E3:G3", consRanges[3].RangeAddress.ToString()); }
public void ConsolidateWideRangesSameWorksheet() { var wb = new XLWorkbook(); var ws = wb.Worksheets.Add("Sheet1"); var ranges = new XLRanges(); ranges.Add(ws.Row(5)); ranges.Add(ws.Row(7)); ranges.Add(ws.Row(6)); ranges.Add(ws.Column("D")); ranges.Add(ws.Column("F")); ranges.Add(ws.Column("E")); var consRanges = ranges.Consolidate() .OrderBy(r => r.Worksheet.Name) .ThenBy(r => r.RangeAddress.FirstAddress.RowNumber) .ThenBy(r => r.RangeAddress.FirstAddress.ColumnNumber) .ToList(); Assert.AreEqual(3, consRanges.Count); Assert.AreEqual("D:F", consRanges[0].RangeAddress.ToString()); Assert.AreEqual("A5:C7", consRanges[1].RangeAddress.ToString()); Assert.AreEqual("G5:XFD7", consRanges[2].RangeAddress.ToString()); }