Как я могу прочитать указанный диапазон в Excel, используя OpenXML - PullRequest
0 голосов
/ 06 мая 2018

Я хочу прочитать указанные диапазоны ячеек строки.

Например:

  • Начните с строки = 3 и столбца = 8 до строки = 3 и столбца = 25
  • Начните с строки = 7 и столбца = 4 до строки = 7 и столбца = 32

Я могу получить информацию WorkSheet, используя OpenXML. ( Официальный документ здесь)

WorkbookPart workbookPart = spreadsheetDocument.WorkbookPart;
WorksheetPart worksheetPart = workbookPart.WorksheetParts.First();
SheetData sheetData = worksheetPart.Worksheet.Elements<SheetData>().First();
string text;

foreach (Row r in sheetData.Elements<Row>())
{
    foreach (Cell c in r.Elements<Cell>())
    {
        text = c.CellValue.Text;
        Console.Write(text + " ");
    }
}

Но я не хочу использовать foreach, как это. Потому что некоторые документы такие длинные или некоторые указанные строки и ячейки объединены.

Мне нужен метод, который читает диапазон.

1 Ответ

0 голосов
/ 09 мая 2018

Вы можете перебирать нужные ячейки, просто циклически изменяя диапазон:

class Program
{
    static void Main(string[] args)
    {
        int rowStart = 1;
        string colStart = "Y";
        int rowEnd = 5;
        string colEnd = "AC";
        string currentRow = colStart;
        bool done = false;
        // check if rowStart < rowEnd && colStart < colEnd

        using (document = SpreadsheetDocument.Open(filePath, true))
        {
            WorkbookPart wbPart = document.WorkbookPart;
            Worksheet sheet = wbPart.WorksheetParts.First().Worksheet;
            for (; ; )
            {
                for (int i = rowStart; i <= rowEnd; i++)
                {
                    // Your cell
                    Cell cell = GetCell(sheet, currentRow, i);
                }

                currentRow = GetNextColumn(currentRow);
                if (done)
                {
                    break;
                }
                if (currentRow == colEnd)
                {
                    done = true;
                }
            }
        }
        Console.Read();
    }

    private static Cell GetCell(Worksheet worksheet,
        string columnName, uint rowIndex)
    {
        Row row = GetRow(worksheet, rowIndex);

        if (row == null)
            return null;

        return row.Elements<Cell>().Where(c => string.Compare
                                               (c.CellReference.Value, columnName +
                                                                       rowIndex, true) == 0).First();
    }


    // Given a worksheet and a row index, return the row.
    private static Row GetRow(Worksheet worksheet, uint rowIndex)
    {
        return worksheet.GetFirstChild<SheetData>().
            Elements<Row>().Where(r => r.RowIndex == rowIndex).First();
    }

    static string GetNextColumn(string col)
    {
        char[] charArr = col.ToCharArray();
        var cur = Convert.ToChar((int) charArr[charArr.Length - 1]);
        if (cur == 'Z')
        {
            if (charArr.Length == 1)
            {
                return "AA";
            }
            else
            {
                char[] newArray = charArr.Take(charArr.Length - 1).ToArray();
                var ret = GetNextColumn(new string(newArray));
                return ret + "A";
            }
        }
        charArr[charArr.Length - 1] = Convert.ToChar((int)charArr[charArr.Length - 1] + 1);
        return new string(charArr);

    }
}
...