2

open xml sdk でいくつかの .xslx ファイルを読み込もうとしていますが、良い例を見つけるのに本当に苦労しています。

私がやりたいことは、XSLX ファイル全体を読み取り、すべての行をループして、指定した列から cellvalue/celltext を抽出することです。

次のように:

GetCellText(rowId, ColumnLetter)

これは可能ですか?

4

2 に答える 2

2

ヘルパー:

private static string GetColumnName(string cellReference)
{
    if (ColumnNameRegex.IsMatch(cellReference))
        return ColumnNameRegex.Match(cellReference).Value;

    throw new ArgumentOutOfRangeException(cellReference);
}

private static readonly Regex ColumnNameRegex = new Regex("[A-Za-z]+");

コード:

using (var document = SpreadsheetDocument.Open(stream, true))
        {
            var sheets = document.WorkbookPart.Workbook.Descendants<Sheet>();

            foreach (Sheet sheet in sheets)
            {

                WorksheetPart worksheetPart = (WorksheetPart)document.WorkbookPart.GetPartById(sheet.Id);
                Worksheet worksheet = worksheetPart.Worksheet;
                var rows = worksheet.GetFirstChild<SheetData>().Elements<Row>();
                foreach (var row in rows)
                {
                    var cells = row.Elements<Cell>();
                    foreach (var cell in cells)
                    {
                        if(GetColumnName(cell.CellReference) == "A")
                        {
                            var str = cell.CellValue.Text;
                            // do whatewer you want
                        }
                    }
                }
            }

        }
于 2012-11-16T07:42:05.913 に答える
0

あなたの質問はこれに似ています

1) XML Excel 読み取りセル値を開く

ID で行を取得し、列名で値を検索できます。

それが役立つことを願っています

于 2012-11-16T07:40:02.743 に答える