NPOI 导出Excel表报错
当导出2007格式的时候,打开文件总是报错“发现 xxx中的部分内容有问题。是否让我们尽量尝试恢复?”。

导出的程序:
protected void btnValidateInternalData_Click(object sender, EventArgs e)
{
if (!FileUploadEmployee.HasFile)
{
ShowMessage("请先选择文件。");
return;
} var employeeData = GetDataTable();
if (employeeData.Rows.Count == )
{
ShowMessage("文件数据为空。");
return;
} ValidateEmployeeField(employeeData); var fileName = FileUploadEmployee.FileName;
DataSet dataSet = new DataSet();
dataSet.Tables.Add(employeeData);
byte[] fileBinary = null;
fileBinary = ExcelHelper.ExportToExcel(dataSet, DataFormat.Excel2007);
var reportFileName = Path.GetFileNameWithoutExtension(fileName) + "Validated" + DateTime.Now.ToString("yyyyMMddHHmmss") + Path.GetExtension(fileName);
Response.Buffer = true;
Response.Clear();
Response.ClearHeaders();
Response.ClearContent();
Response.AddHeader("Content-Disposition", @"attachment;filename=""" + reportFileName + @"""");
Response.AddHeader("Content-Length", fileBinary.Length.ToString());
Response.ContentType = "application/vnd.ms-excel"; //"application/octet-stream";
Response.BinaryWrite(fileBinary);
//说明:当仅使用Response.End()发送缓冲输出时,打开导出的excel会出现 部分内容有问题 的错误。
Response.Flush();//向客户端发送当前所有缓冲的输出。
Response.End();//将当前所有缓冲的输出发送到客户端,停止该页的执行,并引发 EndRequest 事件。
}
从dataset创建excel表格的方法:
public static byte[] ExportToExcel(DataSet origDataSet, DataFormat dataFormat, string culture = "", bool shouldCheckHideColumnsForReport = false)
{
IWorkbook workbook = null;
switch (dataFormat)
{
case DataFormat.Excel97_2003:
workbook = new HSSFWorkbook();
break;
case DataFormat.Excel2007:
workbook = new XSSFWorkbook();
break;
} ICellStyle cellstyleDate = workbook.CreateCellStyle();
short df = workbook.CreateDataFormat().GetFormat(DateUtils.FORMAT_DATETIME);
if (culture == new Language(LanguageEnum.zhcn).Code)
df = workbook.CreateDataFormat().GetFormat(DateUtils.FORMAT_DATETIME);
cellstyleDate.DataFormat = df; foreach (DataTable dt in origDataSet.Tables)
{
ISheet sheet = workbook.CreateSheet(dt.TableName); int columnIndex = ;
IRow row = sheet.CreateRow();
ICell cell;
foreach (DataColumn dc in dt.Columns)
{
string columnName = dc.ColumnName;
if (shouldCheckHideColumnsForReport && ShouldSkipColumnForReport(columnName))
{
//dont add this column in this external report
continue;
}
cell = row.CreateCell(columnIndex);
cell.SetCellValue(dc.ColumnName); columnIndex++;
} List<int> lockedColumnList = new List<int>();
int rowIndex = ;
foreach (DataRow dr in dt.Rows)
{
row = sheet.CreateRow(rowIndex);
columnIndex = ;
foreach (DataColumn dc in dt.Columns)
{
string columnName = dc.ColumnName;
if (shouldCheckHideColumnsForReport && ShouldSkipColumnForReport(columnName))
{
//dont add this column in this external report
continue;
}
cell = row.CreateCell(columnIndex); if (dc.DataType == Type.GetType("System.DateTime"))
{
DateTime dateTime = DateTime.MinValue;
if (DateTime.TryParse(dr[columnName].ToString(), out dateTime))
{
cell.CellStyle = cellstyleDate;
cell.SetCellValue(dateTime);
}
else
cell.SetCellValue(dr[columnName].ToString());
}
else if (dc.DataType == Type.GetType("System.Decimal"))
{
double decimalValue = ;
if (double.TryParse(dr[columnName].ToString(), out decimalValue))
{
cell.SetCellValue(decimalValue);
}
else
cell.SetCellValue(dr[columnName].ToString());
}
else
{
string columnValue = dr[columnName].ToString();
cell.SetCellValue(columnValue);
}
columnIndex++;
}
rowIndex++;
}
}
Response.Flush() Response.End()的区别
//Response.Flush() 将缓存中的内容立即显示出来
//Response.End() 缓冲的输出发送到客户端 停止页面执行
//例:
//Response.Write("520");
//Response.End(); \\执行到这里结束页面显示"520" 下面的语句不再执行 (和没写一样)
//Response.Write("025");
//如果是Response.Flush() 将缓存中的内容立即显示出来,然后再执行后面的语句
NPOI 导出Excel表报错的更多相关文章
- NPOI导出Excel (C#) 踩坑 之--The maximum column width for an individual cell is 255 charaters
/******************************************************************* * 版权所有: * 类 名 称:ExcelHelper * 作 ...
- NPOI导出EXCEL报_服务器无法在发送 HTTP 标头之后追加标头
虽然发表了2篇关于NPOI导出EXCEL的文章,但是最近再次使用的时候,把以前的代码粘贴过来,居然报了一个错误: “服务器无法在发送 HTTP 标头之后追加标头” 后来也查询了很多其他同学的文章,都没 ...
- NPOI导出Excel及使用问题
NPOI导出Excel及使用问题 因为最近公司质管部门提出了一个统计报表的需求:要求导出一个2016及2017年度深圳区域的所有供应商的费用成本计算--一个22列的Excel表,其中还包括多列的合并单 ...
- Asp.Net 使用Npoi导出Excel
引言 使用Npoi导出Excel 服务器可以不装任何office组件,昨天在做一个导出时用到Npoi导出Excel,而且所导Excel也符合规范,打开时不会有任何文件损坏之类的提示.但是在做导入时还是 ...
- NPOI导出EXCEL 打印设置分页及打印标题
在用NPOI导出EXCEL的时候设置分页,在网上有查到用sheet1.SetRowBreak(i)方法,但一直都没有起到作用.经过研究是要设置 sheet1.FitToPage = false; 而 ...
- .NET NPOI导出Excel详解
NPOI,顾名思义,就是POI的.NET版本.那POI又是什么呢?POI是一套用Java写成的库,能够帮助开发者在没有安装微软Office的情况下读写Office的文件. 支持的文件格式包括xls, ...
- NPOI导出Excel(含有超过65335的处理情况)
NPOI导出Excel的网上有很多,正好自己遇到就学习并总结了一下: 首先说明几点: 1.Excel2003及一下:后缀xls,单个sheet最大行数为65335 Excel2007 单个sheet ...
- [转]NPOI导出EXCEL 打印设置分页及打印标题
本文转自:http://www.cnblogs.com/Gyoung/p/4483475.html 在用NPOI导出EXCEL的时候设置分页,在网上有查到用sheet1.SetRowBreak(i)方 ...
- java导出excel报错:getOutputStream() has already been called for this response
对于java导出excel报错的问题,查了很多都说是在使用完输出流以后调用以下两行代码即可 out.clear(); out = pageContext.pushBody(); 但这也许是页面上输出时 ...
随机推荐
- P5331 [SNOI2019]通信 [线段树优化建图+最小费用最大流]
这题真让人自闭-我EK费用流已经死了?- (去掉define int long long就过了) 我建的边害死我的 spfa 还是spfa已经死了? 按费用流的套路来 首先呢 把点 \(i\) 拆成两 ...
- [Python]python对csv去除重复行 python 2020.2.11
用pandas库的.drop_duplicates函数 代码如下: import shutil import pandas as pd frame=pd.read_csv('E:/bdbk.csv', ...
- STL标准库面试题(转)
一.vector的底层(存储)机制 二.vector的自增长机制 三.list的底层(存储)机制 四.什么情况下用vector,什么情况下用list 五.list自带排序函数的排序原理 六.deque ...
- [ZJOI2011] 最小割 - 最小割树
最小割树裸题 建树后,以每个点为根跑DFS求出距离矩阵,然后暴力回答询问即可 #include <bits/stdc++.h> using namespace std; #define i ...
- Linux环境C语言斐波拉切数列(1,1,2,3,5,8,13,.........)实现
斐波那契数列(Fibonacci sequence),又称黄金分割数列.因数学家列昂纳多·斐波那契(Leonardoda Fibonacci)以兔子繁殖为例子而引入,故又称为“兔子数列”,指的是这样一 ...
- Oracle11g配置监听
步骤 1.在windows系统上安装好Oracle后,点击右下角开始菜单Oracle目录下选择Net Manager进行配置,也可以使用Net Configuration Assistant(建议使用 ...
- cc.formatStr()用法
cc.formatStr() 第一个变量为含有 %s 或 %d 的字符串 后面依次为%s或%d对应的内容
- 题解【洛谷P1967】[NOIP2013]货车运输
题面 题解 注意到有一些限重很低的边不会被走到. 于是考虑建一棵最大生成树,在生成树上寻找答案. 设\(f[i][j]\)表示\(i\)的\(2^j\)级祖先,\(w[i][j]\)表示\(i\)到\ ...
- Motif
Motif discovery is in loose terms the problem of finding interesting patterns in sequences. motif: i ...
- Linux_oracle 数据库监听
su - oracle //切换到oracle用户模式下 cd $ORACLE_home/bin //进入oracle安装目录 lsnrctl start //启动监听 lsnrctl status ...