首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >npoi日期格式

npoi日期格式
EN

Stack Overflow用户
提问于 2012-06-18 14:21:10
回答 1查看 4.6K关注 0票数 2

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

注意到,如果在Microsoft中打开文件,将列大小设置为autoset,则保存它,

我不能使用这个解决方案,因为在生产中没有安装excel

PC。

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

使用NPOI并保存此文件。我打开excel,上面写着文件被破坏了,需要

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

我发现,如果我打开文件autoset date列保存excel使用

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

  1. 所以我决定使用NPOI进行自动设置代码,它不会增加日期

的宽度

列,相反,它在那里显示数字。

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

日期。在此块之前或之后,我尝试过autoset代码,没有更改。

代码语言:javascript
复制
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设置为

完成列而不是单元格。

假的

EN

回答 1

Stack Overflow用户

发布于 2014-02-25 16:02:37

我使用它自动设置列宽:

代码语言:javascript
复制
HSSFSheet sheet = (HSSFSheet)workbook.GetSheetAt(x);
sheet.AutoSizeColumn(y);

其中x是工作表号,y是列号。这至少会设置宽度,以便excel不显示###。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/11084846

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档