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(); 但这也许是页面上输出时 ...
随机推荐
- BZOJ 2467: [中山市选2010]生成树
有一种图形叫做五角形圈.一个五角形圈的中心有1个由n个顶点和n条边组成的圈.在中心的这个n边圈的每一条边同时也是某一个五角形的一条边,一共有n个不同的五角形.这些五角形只在五角形圈的中心的圈上有公共的 ...
- python数据分析学习(1)pandas一维工具Series讲解
目录 一:pandas数据结构介绍 python是数据分析的主要工具,它包含的数据结构和数据处理工具的设计让python在数据分析领域变得十分快捷.它以NumPy为基础,并对于需要类似 for循环 ...
- springboot~集成DataSource 与 Druid监控配置
介绍 Druid首先是一个数据库连接池.Druid是目前最好的数据库连接池,在功能.性能.扩展性方面,都超过其他数据库连接池,Druid已经在阿里巴巴部署了超过600个应用,经过一年多生产环境大规模部 ...
- cenos7 安装samba
1)安装samba应用# yum install samba samba-client2)启动Samba应用 systemctl start smb nmb3)Samba配置文件 /etc/samba ...
- day:3.9基础复习
1.不要在模块之间相互调用,否则会出现麻绳现象,避免循环导入. ==:用来判断值是否相等(分别指向两个空间,但是空间里面的内容相同) is:判断指向是否相等. 例: a=[,,] b=[,,] a== ...
- windows系统使用sketch设计的设计稿
由sketch设计的文件因为没有windows系统的sketch所以无法使用windows系统的电脑打开,那么怎么办呢?可以借助zeplin, 通过sketch(mac电脑)上传到zeplin账号,然 ...
- wa自动机 的 莫队 刷题记录
洛谷P2709小B的询问 莫队裸题,模板题 莫队就是把询问区间排个序,先按左端点的Pos排序(POS是分块那个数组),pos一样的按右端点排序 代码: #include <bits/stdc++ ...
- vscode设置成中文
打开 VS Code Ctrl + Shift +p打开搜索框 搜索框内输入Configure Display Language 回车 修改代码中“locale”后面引号内内容为zh-CH 重新启动V ...
- 使用在react hooks+antd ListView简单实现移动端长列表功能
import React, { useState, useEffect } from "react" import { ListView } from "antd-mob ...
- CodeForces - 645 C.Enduring Exodus
快乐二分 用前缀和随便搞一下 #include <cstdio> using namespace std; ; int p[N]; ; inline int msum(int a, int ...