Open XMLSDK2.0を使用してExcelファイルを読み取っています。このファイルには、以下のような情報が含まれています。
番号DataFoundの概要
10 2012-12-12 abslsoddsdls
20 2012-11-12 sllsdislkdrr
Open XML SDKを使用してファイルからデータを取得すると、セルのDataTypeが常にString(sharedstring)として取得されます。Excelファイルの場合と同じようにデータ型を取得する必要があります。以下の私のコードを見てください。Excelファイルにあるようにセルのデータ型を取得するにはどうすればよいですか?
SpreadsheetDocument spreadSheetDocument = SpreadsheetDocument.Open(dataStream, false);
WorkbookPart workbookPart = spreadSheetDocument.WorkbookPart;
IEnumerable<Sheet> sheets = spreadSheetDocument.WorkbookPart.Workbook.GetFirstChild<Sheets>().Elements<Sheet>();
string relationshipId = sheets.First().Id.Value;
WorksheetPart worksheetPart = (WorksheetPart)spreadSheetDocument.WorkbookPart.GetPartById(relationshipId);
Worksheet workSheet = worksheetPart.Worksheet;
SheetData sheetData = workSheet.GetFirstChild<SheetData>();
IEnumerable<Row> rows = sheetData.Descendants<Row>();
foreach (Cell cell in rows.ElementAt(0))
{
dt.Columns.Add(GetCellValue(spreadSheetDocument, cell));
}
foreach (Row row in rows) //this will also include your header row...
{
DataRow tempRow = dt.NewRow();
for (int i = 0; i < row.Descendants<Cell>().Count(); i++)
{
tempRow[i] = GetCellValue(spreadSheetDocument, row.Descendants<Cell>().ElementAt(i ));
}
dt.Rows.Add(tempRow);
}
dt.Rows.RemoveAt(0);
public static string GetCellValue(SpreadsheetDocument document, Cell cell)
{
SharedStringTablePart stringTablePart = document.WorkbookPart.SharedStringTablePart;
string value = cell.CellValue.InnerXml;
if (cell.DataType != null && cell.DataType.Value == CellValues.SharedString) //cell.DataType is always SharedString!
{
return stringTablePart.SharedStringTable.ChildElements[Int32.Parse(value)].InnerText;
}
else
{
return value;
}
}