OpenXML,SAX和Simply读取Xlsx文件

时间:2012-10-11 20:45:45

标签: c# datatable openxml xlsx

我一直在努力寻找有关如何使用OpenXml读取大型xlsx文件的解决方案。我试过没有运气的微软样本。我只需要在c#中将excel文件读入DataTable。我不关心数据表中的值类型,所有内容都可以存储为字符串值。

到目前为止我找到的样本不保留电子表格的结构,只返回单元格的值。

有什么想法吗?

2 个答案:

答案 0 :(得分:1)

open xml SDK可能有点难以理解。但是,我发现使用http://simpleooxml.codeplex.com/此代码plex项目很有用。它在sdk上添加了一个薄层,可以更轻松地解析excel文件并使用样式。

然后你可以使用类似下面的内容与他们的工作表阅读器一起递送并获取你想要的值

System.IO.MemoryStream ms = Utility.StreamToMemory(xslxTemplate);
using (SpreadsheetDocument document = SpreadsheetDocument.Open(ms, true))
{
    IEnumerable<Sheet> sheets = document.WorkbookPart.Workbook.GetFirstChild<Sheets>().Elements<Sheet>();
    if (sheets.Count() == 0)
    {
        // The specified worksheet does not exist.
        return null;
    }
    string relationshipId = sheets.First().Id.Value;
    WorksheetPart worksheetPart = (WorksheetPart)document.WorkbookPart.GetPartById(relationshipId);
    string myval =WorksheetReader.GetCell("A", 0, worksheetPart).CellValue.InnerText;
    // Put in a loop to go through contents of document
}

答案 1 :(得分:0)

您可以通过以下方式获取DataTable:

using (SpreadsheetDocument spreadsheet = SpreadsheetDocument.Open(fileName, false))
{
    DataTable data = ToDataTable(spreadsheet, "Employees");
}

此方法将Excel工作表数据读取为DataTable

public DataTable ToDataTable(SpreadsheetDocument spreadsheet, string worksheetName)
{
    var workbookPart = spreadsheet.WorkbookPart;

    var sheet = workbookPart
        .Workbook
        .Descendants<Sheet>()
        .FirstOrDefault(s => s.Name == worksheetName);

    var worksheetPart = sheet == null
        ? null
        : workbookPart.GetPartById(sheet.Id) as WorksheetPart;

    var dataTable = new DataTable();

    if (worksheetPart != null)
    {
        var sheetData = worksheetPart.Worksheet.GetFirstChild<SheetData>();

        foreach (Row row in sheetData.Descendants<Row>())
        {
            var values = row
                .Descendants<Cell>()
                .Select(cell =>
                {
                    var value = cell.CellValue.InnerXml;
                    if (cell.DataType != null && cell.DataType.Value == CellValues.SharedString)
                    {
                        value = workbookPart
                            .SharedStringTablePart
                            .SharedStringTable
                            .ChildElements[int.Parse(value)]
                            .InnerText;
                    }
                    return (object)value;
                })
                .ToArray();

            dataTable.Rows.Add(values);
        }
    }

    return dataTable;
}