Ячейка формата даты NPOI
Я использую NPOI для создания фиксированного шаблона листа в Sheet1, и мне нужны данные из Sheet2 в формате даты. Я генерирую DataTable из базы данных, чтобы установить данные в Sheet2. Это мой код:
private DataTable getWeek()
{
strConn = WebConfigurationManager.ConnectionStrings["myConn"].ConnectionString;
conn = new OdbcConnection(strConn);
conn.Open();
sql = "SELECT week, sunday, saturday FROM tb_weekreferences";
da = new OdbcDataAdapter(sql, conn);
dt = new DataTable();
da.Fill(dt);
conn.Close();
return dt;
}
и затем экспортируйте DataTable в Excel:
private int ExportDataTableToExcel(DataTable sourceTable, ISheet sheet)
{
IRow headerRow = sheet.CreateRow(0);
ICell headerCell;
ICell cell = null;
Dictionary<String, ICellStyle> styles = CreateExcelStyles(hssfwb);
//handling value
int rowIdx = 1;
foreach (DataRow row in sourceTable.Rows)
{
IRow dataRow = sheet.CreateRow(rowIdx);
foreach (DataColumn column in sourceTable.Columns)
{
cell = dataRow.CreateCell(column.Ordinal);
cell.SetCellValue(row[column].ToString());
cell.CellStyle.DataFormat = HSSFDataFormat.GetBuiltinFormat("");
cell.CellStyle = styles["cell"];
}
rowIdx++;
}
//handling header
foreach (DataColumn column in sourceTable.Columns)
{
headerCell = headerRow.CreateCell(column.Ordinal);
headerCell.SetCellValue(column.ColumnName);
headerCell.CellStyle = styles["header"];
sheet.AutoSizeColumn(column.Ordinal);
sheet.SetColumnWidth(column.Ordinal, (sheet.GetColumnWidth(column.Ordinal) + (5 * 256))); // set width = autofit() + (5 * 256)
}
return rowIdx;
}
В Sheet1 я использую формулу vlookup, чтобы получить "воскресенье" и "субботу" от Sheet2. Но это не работает, потому что значение недели, воскресенья и субботы в Sheet2 выглядит как строка (ячейка выравнивания по левому краю). Как установить формат ячейки в дату, когда генерировать данные, чтобы преуспеть? Пожалуйста, дайте мне решение для этого.
Благодарю.
1 ответ
Первая проблема - эта линия
cell.SetCellValue(row[column].ToString());
Вы конвертируете значение в строку, но, вероятно, конвертируете его в формат DateTime, поэтому NPOI знает, что это datetime.
или попробуйте, если это работает:
cell.SetCellValue(DateTime.Now);
Во-вторых, попробуйте сначала установить стиль для вашей ячейки, а затем измените его атрибут DataFormat, но с пользовательским форматом, подобным этому:
IDataFormat dataFormatCustom = workbook.CreateDataFormat();
cell.CellStyle = styles["cell"];
cell.CellStyle.DataFormat = dataFormatCustom.GetFormat("yyyyMMdd HH:mm:ss");
который отформатирует ваше значение DateTime в удобочитаемый формат.