关于NPOI导出EXCEL的灵异问题.求各位大大帮忙解决下.

叫我猫爷_ 2017-11-02 06:54:34
项目原来有一个页面是可以导出列表到excel的,就在后台构建好集合,然后调用下面的方法之后就可以导出了(填充数据的代码就不贴了),可以导出的意思是浏览器自动下载那个excel..(360会弹个框出来选择路径,谷歌自动下载到默认的路径)
   
NpoiExcelHelper nopi = new NpoiExcelHelper();
DataTable table = nopi.ListToDataTable(list); --list是IList类型
nopi.Write(table, "", "sheetName", strFieldsName, strFieldsTitle, --strFieldsName是list的对象名,strFieldsTitle是表头
tj, '',"导出.xls",maintainStaffNameDic); --tj是用来sheet2的统计信息的,maintainStaffNameDic是用来sheet2的信息之一.



public void Write(DataTable table, string headerText, string sheetName,
string[] columnName, string[] columnTitle, MalfunctionHandleTJ tj,
string headerText1, string fileName, Dictionary<string, int> maintainStaffNameDic)
{
HttpContext context = HttpContext.Current;
context.Response.ContentType = "application/vnd.ms-excel";
context.Response.AddHeader("Content-Disposition", string.Format("attachment;filename={0}", HttpUtility.UrlEncode(fileName, Encoding.UTF8)));
context.Response.Clear();
HSSFWorkbook hssfworkbook = GenerateData(table, headerText, sheetName,
columnName, columnTitle, tj, headerText1, maintainStaffNameDic);
context.Response.BinaryWrite(WriteToStream(hssfworkbook).GetBuffer());
context.Response.End();
}


现在我有另外一个页面也需要导出列表到excel,同样也是调用对应的方法. 但是问题来了,执行完之后,没报错,数据也填充好了,表头和list对象名,list的数据内容都没问题的..
但是却导不出excel(360没弹出框,谷歌也没有自动下载).

NpoiExcelHelper nopi = new NpoiExcelHelper();
DataTable table = nopi.ListToDataTable(list);
nopi.Write(table, "", "sheetName", strFieldsName, strFieldsTitle, "导出.xls");


public void Write(DataTable table, string headerText, string sheetName,
string[] columnName, string[] columnTitle, string fileName)
{
HttpContext context = HttpContext.Current;
context.Response.ContentType = "application/vnd.ms-excel";
context.Response.AddHeader("Content-Disposition", string.Format("attachment;filename={0}", HttpUtility.UrlEncode(fileName, Encoding.UTF8)));
context.Response.Clear();
HSSFWorkbook hssfworkbook = null;
hssfworkbook = GenerateData(table, headerText, sheetName,
columnName, columnTitle);
context.Response.BinaryWrite(WriteToStream(hssfworkbook).GetBuffer());
context.Response.End();
}



两份填充数据的代码都是一样的,调用的方法也是一样的.
...全文
309 8 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
叫我猫爷_ 2017-11-08
  • 打赏
  • 举报
回复
引用 6 楼 cyg17173 的回复:
页面有特殊字符。
导出的内容有特殊字符?
cyg17173 2017-11-07
  • 打赏
  • 举报
回复
页面有特殊字符。
好大一地嗯 2017-11-07
  • 打赏
  • 举报
回复
1、这个不能在异步中ajax请求 2、直接POST或GET请求这个页面下载文件 3、debug确定这个代码被执行了
吉普赛的歌 2017-11-05
  • 打赏
  • 举报
回复
直接导出为一个真实的文件, 给人家一个 url 就可以了, 不要 reponse 搞来搞去容易出问题。
  • 打赏
  • 举报
回复
你应该首先进行 http 调试,看看到底是不是要下载。
叫我猫爷_ 2017-11-05
  • 打赏
  • 举报
回复
自顶~~~~~~~~~~~~~~~~~~~
叫我猫爷_ 2017-11-04
  • 打赏
  • 举报
回复
顶~~~~~~~~~~
叫我猫爷_ 2017-11-02
  • 打赏
  • 举报
回复
自顶~~~~~~~~~~~~~~~~~~~
具体内容请参考我的BLOG:http://blog.csdn.net/smallwhiteyt/archive/2009/11/08/4784771.aspx 如果你耐心仔细看完本文,相信以后再遇到导出EXCLE操作的时候你会很顺手觉得SO EASY,主要给新手朋友们看的,老鸟可以直接飘过了,花了一晚上的时间写的很辛苦,如果觉得对你有帮助烦请留言支持一下,我会写更多基础的原创内容来回报大家。 C#导出数据到EXCEL表格是个老生常谈的问题了,写这篇文章主要是给和我一样的新手朋友提供两种导出EXCEL的方法并探讨一下导出的效率问题,本文中的代码直接就可用,其中部分代码参考其他的代码并做了修改,抛砖引玉,希望大家一起探讨,如有不对的地方还请大家多多包涵并指出来,我也是个新手,出错也是难免的。 首先先总结下自己知道的导出EXCEL表格的方法,大致有以下几种,有疏漏的请大家补充。 1.数据逐条逐条的写入EXCEL 2.通过OLEDB把EXCEL做为数据源来写 3.通过RANGE范围写入多行多列内存数据到EXCEL 4.利用系统剪贴板写入EXCEL 好了,我想这些方法已经足够完成我们要实现的功能了,方法不在多,在精,不是么?以上4中方法都可以实现导出EXCEL,方法1为最基础的方法,意思就是效率可能不是太高,当遇到数据量过大时所要付出的时间也是巨大的,后面3种方法都是第一种的衍生,在第一种方法效率低下的基础上改进的,这里主要就是一个效率问题了,当然如果你数据量都很小,我想4种方法就代码量和复杂程度来说第1种基本方法就可以了,或当你的硬件非常牛逼了,那再差的方法也可以高效的完成也没有探讨的实际意义了,呵呵说远了,本文主要是在不考虑硬件或同等硬件条件下单从软件角度出发探讨较好的解决方案。

111,095

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • AIGC Browser
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧