我正在嘗試使用打開的xml sdk讀取一些.xslx文件,但我真的很難找到任何好的示例。如何使用基於C#中每行的列的開放XML SDK讀取xslx?
我想要做的是讀取整個XSLX文件並遍歷所有行並從我指定的列中提取cellvalue/celltext。
類似如下:
GetCellText(rowId, ColumnLetter)
這可能嗎?
我正在嘗試使用打開的xml sdk讀取一些.xslx文件,但我真的很難找到任何好的示例。如何使用基於C#中每行的列的開放XML SDK讀取xslx?
我想要做的是讀取整個XSLX文件並遍歷所有行並從我指定的列中提取cellvalue/celltext。
類似如下:
GetCellText(rowId, ColumnLetter)
這可能嗎?
助手:
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
}
}
}
}
}
好吧,但我需要循環通過工作表,並設置rowvalue基於.. – user1828871
對不起。我的意思是rowId。 – user1828871
如果我正確地理解了這一點,這將返回工作表的前十行,但我想遍歷整個工作表,所以如何獲取長度? – user1828871
如果 「只」 想讀你可能想嘗試EPPLUS的XLSX。這是一個用於重新寫入/寫入xlsx文件的免費庫。比SDK更容易處理。 –
謝謝!是在記錄起牀和運行:) – user1828871