2

1枚のExcelファイルに3つのテーブルがあり、OpenXMLSDKを使用して次のようにExcelファイルを読み取ります。

SpreadSheetDocument document = SpreadSheetDDocument.open(/*read it*/);
foreach(Sheet sheet in document.WorkbookPart.Workbook.Sheets)
{
   //I need each table or work part of sheet here
}

ご覧のとおり、Excelの各シートを取得できますが、これらのテーブルで反復処理できる3つのテーブルのように、各シートでワークパーツを取得するにはどうすればよいですか。なにか提案を?

4

2 に答える 2

8

これは役に立ちますか?

// true for editable
using (SpreadsheetDocument xl = SpreadsheetDocument.Open("yourfile.xlsx", true))
{
    foreach (WorksheetPart wsp in xl.WorkbookPart.WorksheetParts)
    {
        foreach (TableDefinitionPart tdp in wsp.TableDefinitionParts)
        {
            // for example
            // tdp.Table.AutoFilter = new AutoFilter() { Reference = "B2:D3" };
        }
    }
}

実際のセルデータはTableオブジェクトではなく、SheetData(WorksheetPartのWorksheetの下)にあることに注意してください。ちょうどあなたが知っているので。

于 2013-01-22T14:11:41.060 に答える
0

あなたはExcelから特定のテーブルを得ることができます。@Vincentの答えにさらに追加する

using (SpreadsheetDocument document= SpreadsheetDocument.Open("yourfile.xlsx", true))
{
    var workbookPart = document.WorkbookPart;
    var relationsShipId = workbookPart.Workbook.Descendants<Sheet>()
                    .FirstOrDefault(s => s.Name.Value.Trim().ToUpper() == "your sheetName")?.Id;

    var worksheetPart = (WorksheetPart)workbookPart.GetPartById(relationsShipId);

    TableDefinitionPart tableDefinitionPart = worksheetPart.TableDefinitionParts
                                                                       .FirstOrDefault(r =>
                                                                         r.Table.Name.Value.ToUpper() =="your Table Name");

    QueryTablePart queryTablePart = tableDefinitionPart.QueryTableParts.FirstOrDefault();

    Table excelTable = tableDefinitionPart.Table;

    var newCellRange = excelTable.Reference;
    var startCell = newCellRange.Value.Split(':')[0]; // you can have your own logic to find out row and column with this values
    var endCell = newCellRange.Value.Split(':')[1];// Then you can use them to extract values using regular open xml 
}
于 2022-01-14T21:35:21.083 に答える