DataGrid或GridView 生成Excel后,打开这个Excel会弹出"您尝试打开的文件的格式与文件扩展名指定的格式不一致"

bdcman 2009-03-22 01:08:18
导出Excel的代码很普通,网络上大致相同:
private void ToExcel(DataGrid grid, string FileName)
{
HttpContext.Current.Response.Charset = "UTF-8";
HttpContext.Current.Response.ContentEncoding = System.Text.Encoding.UTF8;
HttpContext.Current.Response.ContentType = "application/ms-excel";
HttpContext.Current.Response.AppendHeader("Content-Disposition", "attachment;filename=" + "" + FileName);
System.IO.StringWriter tw = new System.IO.StringWriter();
HtmlTextWriter hw = new HtmlTextWriter(tw);
grid.RenderControl(hw);
HttpContext.Current.Response.Write(tw.ToString());
HttpContext.Current.Response.End();
}

导出Excel打开时,会弹出提示"您尝试打开的文件的格式与文件扩展名指定的格式不一致" ,有没有什么办法可以解决这个问题,不要是修改注册表之类

估计DataGrid转成Excel是被保存成了html格式的Excel文件,有什么办法可以改变成正常的Excel格式呢
...全文
2022 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
wuyq11 2009-03-22
  • 打赏
  • 举报
回复
http://social.microsoft.com/Forums/zh-CN/visualcshartzhchs/thread/77ae2b95-ecaa-46a3-a0ba-1648a242bd99/
trueideal 2009-03-22
  • 打赏
  • 举报
回复
第一列的名字是大写的了,这个鬼问题我遇到过.
铭记园园 2009-03-22
  • 打赏
  • 举报
回复
HttpContext.Current.Response.AppendHeader("Content-Disposition", "attachment;filename=" + "" + FileName);
改为

HttpContext.Current.Response.AppendHeader("Content-Disposition", "attachment;filename=fileName.xls" );
bdcman 2009-03-22
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 trueideal 的回复:]
第一列的名字是大写的了,这个鬼问题我遇到过.
[/Quote]

第一列名字大写了===这怎么理解啊,请指教.

62,267

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

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