npoi日期格式

时间:2012-06-18 14:21:11

标签: c# xls npoi

我正在使用NPOI 1.2.5.0,Visual Studio 2008.电子表格中有一个日期列。我

观察到,如果我在Microsoft Excel中打开文件,请将列的大小设置为自动设置,保存,

一切正常。我无法使用此解决方案,因为生产

上没有安装excel

PC。

否则,当我处理其他逻辑/编码时,日期列显示####而不是日期

使用NPOI并保存此文件。我打开excel,它说文件已损坏,需要

恢复,数据可能会丢失。如果我点击“是”,它会恢复文件并显示 一切都正确。

我发现这可以解决,如果我打开文件自动设置日期列保存excel使用

Microsoft Excel。在使用NPOI .net代码处理后,它确实打开了。

  1. 所以我决定使用NPOI做autoset thr代码,它不会增加日期的宽度
  2. 列,而是显示那里的数字。

    我编写了以下代码来设置日期格式,但它显示的是数字而不是

    日期。我在此块之后的OR之前尝试了自动设置代码,没有变化。

    for (int i = 0; i <= nTotalRows; i++)
                {
                    HSSFCellStyle cellStyle = (HSSFCellStyle)templateWorkbook.CreateCellStyle();
                    HSSFCell Cell = (HSSFCell)exlSheet.GetRow(i).GetCell(nCheckColumn);
                    //(HSSFCell)exlSheet.Sheet.get .SetDefaultColumnStyle(nCheckColumn,
                    cellStyle.DataFormat = HSSFDataFormat.GetBuiltinFormat("mm-dd-yy");
                    Cell.CellStyle = cellStyle;
                    MemoryStream ms = new MemoryStream();
                    templateWorkbook.Write(ms);
                    ms.Close();
                    FileStream fs1 = new FileStream(strFilePath, FileMode.Create);
                    templateWorkbook.Write(fs1);
                    fs1.Close();
                }
    

    请为此建议解决方案。我正在搜索Getcolumn以将Dataformat设置为

    完整列而不是单元格。

1 个答案:

答案 0 :(得分:1)

我用它来自动设置列宽:

HSSFSheet sheet = (HSSFSheet)workbook.GetSheetAt(x);
sheet.AutoSizeColumn(y);

其中x是表单编号,y是列编号。这将至少设置宽度,因此excel不会显示###