C# npoi日期格式

C# npoi日期格式,c#,xls,npoi,C#,Xls,Npoi,我正在使用NPOI1.2.5.0,VisualStudio2008。电子表格中有一个日期列。我 观察到,如果我在Microsoft Excel中打开文件,将列的大小设置为autoset,然后保存 很好。我不能使用这个解决方案,因为生产环境中没有安装excel 个人电脑 否则,当我处理其他逻辑/编码时,日期列将显示#####,而不是日期 使用NPOI并保存此文件。我打开excel,它显示文件已损坏,需要 恢复后,数据可能会丢失。如果我单击“是”,它将恢复文件并显示 一切正常 我发现这个问题可以解决

我正在使用NPOI1.2.5.0,VisualStudio2008。电子表格中有一个日期列。我

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

很好。我不能使用这个解决方案,因为生产环境中没有安装excel

个人电脑

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

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

恢复后,数据可能会丢失。如果我单击“是”,它将恢复文件并显示 一切正常

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

微软Excel。在使用NPOI.net代码进行处理后,它确实打开ok

  • 所以我决定使用NPOI编写autoset-thr代码,它不会增加日期的宽度
  • 列,而是在那里显示数字

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

    日期。我在这个块之前或之后尝试了自动设置代码,没有改变

    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();
                }
    

    for(int i=0;i我使用此选项自动设置列宽:

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

    其中x是页码,y是列号。这至少可以设置宽度,使excel不会显示####

    很久以前我就发布了这个问题,当时我发布了带有bug的版本。我需要尝试上面的建议。