и формат(тип) ячейки в Excel таблице (программно как можно понять), использую ClosedXML.
Так вот все эти методы при выполнении команды "работают" корректно, но фактически тип данных (формат) не меняют.
Условно: меняю тип данных ячейки на Number
- worksheet.cell("D4").DataType = XLDataType.Number;
Проверяю изменился ли формат:
- MessageBox.Show(Convert.ToString(worksheet.cell("D4").DataType));
/*показывает что тип Number*/
Закрываю программу, открываю .xlsx файл над которым работал, вижу что формат фактически не поменялся (книжку я разумеется сохранил workbook.SaveAs(*sameFName*)) - ну и в разочарованных чувствах появляется желание наложить на кого ни будь руки.
В чем заключается суть этой иллюзии?
По умолчанию все ячейки имеют общий формат. Попробуй через кастомный формат. Конечный формат ячейки какой нужен?
Там вродь должен быть метод на подобии .Close(true) UPD: а хотя это сторонняя либа, может и не быть
Даже если бы существовал метод о котором ты говоришь, прикол заключается в том - что всё остальное работает (вставка значений/ форматирование стилей ячейки/ ширины и прочего), а вот тип данных ячейки нет, прям бесит. Причем явного повода нет, скорее какое то разное понимание типов самой библиотеки и Excel'я. Буду ждать того парня выше))
а, ну я грешил на сохранение, а тут вон что. тогда я тут бессилен😕
https://stackoverflow.com/questions/46421305/closedxml-setting-data-type-for-cell-does-not-work https://stackoverflow.com/questions/33775423/how-to-set-a-data-type-for-a-column-with-closedxml
Да , спасибо конечно - но я копии этих ответов уже десяток видел)) К сожалению ни один метод из предложенных не работает - работают как холостые))
По экселю. Я использую либу ExcelLibrary.dll (у нее запись в xls файлы) по умолчанию без указания типа ячейки сам ексель ее видит как "общий", пример записи значения worksheet.Cells[3, 3] = new Cell(propInfo.Value); если необходимо явное указание экселю типа ячейки, то использую указание формата через строку worksheet.Cells[3, 2] = new Cell(key.GetValue(document), new CellFormat(CellFormatType.Number, "0")); В самой либе есть следующие конструкторы ячейки, но с параметром типа CellFormat экселю так и не удалось указать ячейку с типом "число" могу скинуть саму либу, если нужно
По хорошему не хотелось бы переходить на другую, или 2 использовать - должен же быть способ - потому что у меня как то получилось неявно это сделать в самый первый раз.
Обсуждают сегодня