NPOI 导入导出和Excel版本,错误文件扩展名和文件的格式不匹配

读取时可以自动判断Excel版本

 IWorkbook workbook = NPOI.SS.UserModel.WorkbookFactory.Create(fs); 

调用这个方法,内部自动判断Excel的版本

导出时:

2003之前的版本是

 IWorkbook workbook = new HSSFWorkbook(); 2003版本

ContentType是application/vnd.ms-excel

2003之后的版本是

Workbook workbook = new XSSFWorkbook();//2007版本

ContentType是application/vnd.openxmlformats-officedocument.spreadsheetml.sheet

 

如果写错了,使用office打开会提示,文件扩展名和文件的格式不匹配,但使用WPS打开不会提示。

 

 

发现“中转费2018-10-14--20181016140243.xlsx”中的部分内容有问题。是否让我们尽量尝试恢复? 如果您信任此工作簿的源,请单击“是”。解决方法参考

核心是

 MemoryStream ms = new MemoryStream();
workbook.Write(ms);
 ms.Close();
ms.Dispose();
System.Web.HttpContext.Current.Response.End();
 public static void ExportByWeb(List<TModel> list, string strHeaderText, string strFileName, Dictionary<string, string> FieldNames)
    {     
        ExportToFile<TModel> temp = new ExportToFile<TModel>();
        HttpContext curContext = HttpContext.Current;      
        curContext.Response.AddHeader("Content-Disposition",
            "attachment;filename=" + HttpUtility.UrlEncode(strHeaderText + DateTime.Now.ToString("yyyyMMddHHmmss") + ".xlsx", Encoding.UTF8));
        MemoryStream ms = temp.Export(list, strHeaderText, FieldNames);
        //  new AppException("导出文件开始2" + strHeaderText + DateTime.Now + "导出数据量:" + list.Count);
        if (ms != null)
        {
            curContext.Response.BinaryWrite(ms.ToArray());
        }
        //  new AppException("导出文件结束2" + strHeaderText + DateTime.Now + "导出数据量:" + list.Count);
        ms.Close();
        ms.Dispose();
        curContext.Response.End();
    }

 

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Excel文件格式文件扩展名不一致时,可能会出现乱码问题或无法打开文件的情况。这通常是由于使用第三方库或非正式的方法生成的Excel文件,并且文件扩展名仍然保留为".xls"。为了解决这个问题,可以尝试以下两种方法: 方法一:使用注册表设置 1. 单击"开始",选择"运行",输入"regedit"并点击确定,打开注册表编辑器。 2. 在注册表编辑器中,找到以下注册表子项:HKEY_CURRENT_USER\Software\Microsoft\Office\12.0\Excel\Security。 3. 在右侧空白处点击鼠标右键,选择"新建 -> DWORD值(32位)",输入"ExtensionHardening"并点击确定。 4. 用鼠标右键点击新创建的"ExtensionHardening",然后单击"修改",在数值数据中填写"0"并确定。 5. 关闭注册表编辑器,再次打开xls文件查看是否已经没有了格式文件扩展名不一致的提示。 方法二:使用现有版本保存 1. 先用Excel 2007或2010打开xls格式文件。 2. 将文件另存为"EXCEL工作薄"。 3. 再用Excel 2007打开xlsx格式文件。 4. 将文件另存为"Excel 97-2003 工作簿"。 这两种方法都可以帮助解决格式文件扩展名不一致的问题,使得Excel文件能够正常打开且不出现乱码。另外,如果是开发者需要将DataGridView的数据导出Excel,建议学习使用合适的库(如NPOI)来实现,以确保生成的Excel文件格式正确且与扩展名匹配。 : 引用自 : 引用自

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值