最近在用c#的asp.net,需要批量导出数据。原本用的是stringbuilder逐个填充,但是只能做到html强制格式转换为xls,这不是真正的excel表格,所以在网上找了datatable快速填充到excel的方法。

使用该方法后,发现下载了以后的表格没有办法用exce软件l打开,而且电脑的所有的excel文件都打不开了,重启后才可以,花了一天时间才找到问题所在。

如下图所示,打开表格,什么都不显示,表格名字也不对。

有的人遇到这种情况,可能是视图里面选择了隐藏,需要取消隐藏,但是我并没有隐藏数据,而且这几个按钮点击了就变暗,并没有反应

我觉得是我的代码有问题,就仔细检查了,最后终于发现问题所在了

以下是我的方法

 protected void ExportExcel(System.Data.DataTable dt)
{
if (dt == null || dt.Rows.Count == ) return;
Microsoft.Office.Interop.Excel.Application xlApp = new Microsoft.Office.Interop.Excel.Application();
//Microsoft.Office.Interop.Excel.Application app = new Microsoft.Office.Interop.Excel.ApplicationClass();
if (xlApp == null)
{
return;
} System.Globalization.CultureInfo CurrentCI = System.Threading.Thread.CurrentThread.CurrentCulture;
System.Threading.Thread.CurrentThread.CurrentCulture = new System.Globalization.CultureInfo("en-US");
Microsoft.Office.Interop.Excel.Workbooks workbooks = xlApp.Workbooks;
Microsoft.Office.Interop.Excel.Workbook workbook =
workbooks.Add(Microsoft.Office.Interop.Excel.XlWBATemplate.xlWBATWorksheet);
Microsoft.Office.Interop.Excel.Worksheet worksheet =
(Microsoft.Office.Interop.Excel.Worksheet)workbook.Worksheets[];
Microsoft.Office.Interop.Excel.Range range, range2, range3, range4, range5, range6, range7;
long totalCount = dt.Rows.Count;
//long rowRead = 0;
//float percent = 0;
xlApp.ScreenUpdating = false; //屏幕不跟新,加快速度
int colCount = dt.Columns.Count;//列总数
int rowCount = dt.Rows.Count;//行总数
object[,] objData = new object[rowCount + , colCount];//标题
for (int i = ; i < dt.Columns.Count; i++)
{
worksheet.Cells[, i + ] = dt.Columns[i].ColumnName;
range = (Microsoft.Office.Interop.Excel.Range)worksheet.Cells[, i + ];
range.Interior.ColorIndex = ;
range.Font.Bold = true;
}
//获取实际数据
for (int rowIndex = ; rowIndex < rowCount; rowIndex++)
{
for (int colIndex = ; colIndex < colCount; colIndex++)
{
objData[rowIndex, colIndex] = dt.Rows[rowIndex][colIndex].ToString();
}
}
for (int rowIndex = ; rowIndex < rowCount; rowIndex++)
{
objData2[rowIndex, ] = dt.Rows[rowIndex][].ToString();
objData3[rowIndex, ] = dt.Rows[rowIndex][].ToString();
objData4[rowIndex, ] = dt.Rows[rowIndex][].ToString();
objData5[rowIndex, ] = dt.Rows[rowIndex][].ToString();
objData6[rowIndex, ] = dt.Rows[rowIndex][].ToString();
}
range = (Range)worksheet.Range[xlApp.Cells[, ], xlApp.Cells[rowCount + , colCount]];
range.NumberFormatLocal = "@";//写入到表中的数据格式以文本形式存在
range.Value2 = objData; worksheet.Cells.Columns.AutoFit();
xlApp.Visible = true;
//11.保存表格到根目录下指定名称的文件中
string pathname = "~/Upload" + "/" + "Pks_data" + "/" + (string)Session[AppSetting.SESSION_USERNAME] +
DateTime.Now.Date.ToString("yyyyMMdd") + ".xlsx";
string filePath = Server.MapPath(pathname);//路径
if (System.IO.File.Exists(Path.GetFullPath(filePath)))
{
File.Delete(Path.GetFullPath(filePath));
}
xlApp.ActiveWorkbook.SaveAs(filePath);
xlApp.Quit();
xlApp = null;
GC.Collect();
DownloadFile(pathname);
} public void DownloadFile(string fileRpath)
{
string filepath = Server.MapPath(fileRpath);
Response.ClearHeaders();
Response.Clear();
Response.Expires = ;
Response.Buffer = true;
Response.AddHeader("Accept-Language", "zh-tw");
string name = System.IO.Path.GetFileName(filepath);
System.IO.FileStream files = new FileStream(filepath, FileMode.Open, FileAccess.Read, FileShare.ReadWrite);
byte[] byteFile = null;
if (files.Length == )
{
byteFile = new byte[];
}
else
{
byteFile = new byte[files.Length];
}
files.Read(byteFile, , (int)byteFile.Length);
files.Close(); Response.AddHeader("Content-Disposition", "attachment;filename=" + HttpUtility.UrlEncode(name, System.Text.Encoding.UTF8));
Response.ContentType = "application/octet-stream;charset=gbk";
Response.BinaryWrite(byteFile);
Response.Flush();
Response.End(); }

用了这个方法以后,的确比用stringbuilder快很多,而且可以导出正确格式的xlsx,但是打不开,后来发现问题出在这

 //xlApp.ScreenUpdating = false;  //屏幕不跟新,加快速度    

把这一行注释了以后,就正常了,虽然我也不是很明白原理....


因为只会调用方法,但是不明白方法中每个语句的含义和用法,所以会有很多问题,希望自己能慢慢解决吧

2019-04-21

c#用object将datatable快速填充excel后下载表格后打不开的问题的更多相关文章

  1. DataTable数据导出Excel 并且下载

    public string Excel(System.Data.DataTable dt) { //模板的路径 string strUploadPath = HttpContext.Current.S ...

  2. Excel中筛选两个表中相同的数据和快速填充一列的公式

    将两个工作表放在一个文件中,使用if函数和countif函数判断 =if(判断条件countif(区域,条件),真值,[假值]) 实例 =if(countif(Sheet2!$A$1:$A$44,A2 ...

  3. Excel快速填充

    利用单元格右下角填充句柄进行填充 然后选择快速填充 利用数据面板的快速填充功能(ctrl+e) 年月日三列不能同时填充 只能够一列一列的填充 类别取第一列 级别取第二列 但是由于第一个的编号有两个“1 ...

  4. Excel 快速填充功能介绍以及注意事项

    快速填充 快速填充可以让我们以某种格式来填充单元格. 用"姓氏+职位"格式来快速地填充下面表格中第三列.在第一个单元格内输入"李书记",选中需要被填充的其他单元 ...

  5. [转].net 使用NPOI或MyXls把DataTable导出到Excel

    本文转自:http://www.cnblogs.com/yongfa365/archive/2010/05/10/NPOI-MyXls-DataTable-To-Excel-From-Excel.ht ...

  6. 带复杂表头合并单元格的HtmlTable转换成DataTable并导出Excel

    步骤: 一.前台JS取HtmlTable数据,根据设定的分隔符把数据拼接起来 <!--导出Excel--> <script type="text/javascript&qu ...

  7. DataTable导出到Excel(.NET 4.0)

    最近在论坛里又看到很多关于DataTable(DataSet)导入Excel的帖子,我也温故知新一下,用VS2010重新整理了一个Sample.这个问题简化一下就是内存数据到文件,也就是遍历赋值,只不 ...

  8. DataTable 导出到 Excel 类

    底层类: #region DataTable 导出到 Excel /// <summary> /// DataTable 导出到 Excel /// </summary> // ...

  9. C# DataTable导出EXCEL后身份证、银行卡号等长数字信息显示乱码解决

    在DataTable导出EXCEL后发现有些格式显示有问题,比如身份证.银行卡号等大于11位的数字显示为科学计数法.13681-1等 带中划线的两段数字显示为日期格式等. 处理方法如下: public ...

随机推荐

  1. POJ 2891 Strange Way to Express Integers 中国剩余定理MOD不互质数字方法

    http://poj.org/problem?id=2891 711323 97935537 475421538 1090116118 2032082 120922929 951016541 1589 ...

  2. CUDA杂谈

    这一年都在编写CUDA的程序,用了很多优化的手段,发现大部分其实还是官方的指南里面的手段 https://docs.nvidia.com/cuda/cuda-c-best-practices-guid ...

  3. RabbitMQ使用教程(四)如何通过持久化保证消息99.99%不丢失?

    1. 前情回顾 RabbitMQ使用教程(一)RabbitMQ环境安装配置及Hello World示例 RabbitMQ使用教程(二)RabbitMQ用户管理,角色管理及权限设置 RabbitMQ使用 ...

  4. int,long,long long的数据范围

    unsigned   int   0-4294967295   int   2147483648-2147483647 unsigned long 0-4294967295long   2147483 ...

  5. iOS开发ReactiveCocoa学习笔记(五)

    ReactiveCocoa常见操作方法介绍: demo地址:https://github.com/SummerHH/ReactiveCocoa.git filter ignore ignoreValu ...

  6. bootstrapValidator 重置表单

    最近在公司做业务系统后台,用的js框架还是jquery  ui框架 是以bootstrap为基础的beyondadmin-v1.4.s3这套,用起来还挺不错,所以公司所有的后台ui都使用这套.这套ui ...

  7. [转]linux远程登入不需要密码

    如何通过一台linux ssh远程其他linux服务器时,不要输入密码,可以自动登入.提高远程效率,不用记忆各台服务器的密码. 工具/原料   ssh,ssh-keygen,scp 方法/步骤     ...

  8. linux 命令——6 rmdir(转)

    今天学习一下linux中命令: rmdir命令.rmdir是常用的命令,该命令的功能是删除空目录,一个目录被删除之前必须是空的.(注意,rm - r dir命令可代替rmdir,但是有很大危险性.)删 ...

  9. IOS -刷帧动画(CADisplayLink)

    @property (nonatomic, assign) int imageY; @end @implementation NJView -(void)awakeFromNib { NSLog(@& ...

  10. BZOJ3932(主席树上二分+差分

    按时间作为主席树的版本,每个版本的主席树都是一个权值线段树. 差分消去时间影响 对于当前时间版本的主席树查询前K大即可. 树上二分时结束后切记判定l==r的状态(易错 l==r叶子节点可能存在多个值( ...