Я пытаюсь преобразовать файл .xlsx в формат DataTable с помощью библиотеки NPOI 2.0. Все в порядке, но у меня проблема с преобразованием в строку date date. Когда я пытаюсь использовать конструкцию типа row.GetCell (j) .ToString() - это исключение «Невозможно получить числовое значение из текстовой ячейки». Я попытался использовать свойство DateCellValue, но он также исключил это исключение. С другими форматами ящиков это хорошо. функции, которые я использую это:C#. Импорт ячейки xlsx в DataTable с помощью NPOI 2.0
private DataTable xlsxToDT(string fileName)
{
DataTable table = new DataTable();
XSSFWorkbook workbook = new XSSFWorkbook(new FileStream(fileName, FileMode.Open, FileAccess.Read));
ISheet sheet = workbook.GetSheetAt(0);
IRow headerRow = sheet.GetRow(0);
int cellCount = headerRow.LastCellNum;
for (int i = headerRow.FirstCellNum; i < cellCount; i++)
{
DataColumn column = new DataColumn(headerRow.GetCell(i).StringCellValue);
table.Columns.Add(column);
}
int rowCount = sheet.LastRowNum;
for (int i = (sheet.FirstRowNum); i < sheet.LastRowNum; i++)
{
IRow row = sheet.GetRow(i);
DataRow dataRow = table.NewRow();
for (int j = row.FirstCellNum; j < cellCount; j++)
{
if (row.GetCell(j) != null)
{
//EXCEPTION GENERATING IN THIS CODE
dataRow[j] = row.GetCell(j).ToString();
////////////////////////////
}
}
table.Rows.Add(dataRow);
}
workbook = null;
sheet = null;
return table;
}
UPDATE: Если вставить код, как
row.GetCell(j).SetCellType(CellType.STRING);
в проблемной ячейке у меня есть значение, как "36496.392581018517". Другие ячейки преобразовывались правильно
Я попытался это с ячейкой даты и ошибки не было. Каково содержимое вашей камеры? –
MD.Unicorn, 02.12.1999 9:25:19. Свойство ячейки написано, что это формат даты, но теперь я вижу, что если я скопирую и вставляю ячейку (а не значение ячейки) - она только вставляется «02.12.1999» ... – user2102277
Ничего не кажется неправильным. Какова ценность 'CellType'? –