导出EXCEL,出现GridView方面的错误

在途中 2012-02-13 04:27:13
使用这一方法导出EXCEL,在TempGrid.RenderControl(oHtmlTextWriter)处出现“类型“GridView”的控件“ctl00_ctl00_MainContent_ContentPlaceHolder1_GridView2”必须放在具有 runat=server 的窗体标记内。”这一错误,试问如何解决?

环境:VS2010 VB GiidView2有20行数据


Protected Sub Button4_Click(ByVal sender As Object, ByVal e As System.EventArgs) Handles Button4.Click

GenerateByGridView("导出", GridView2)

End Sub

Public Shared Sub GenerateByGridView(ByVal Typename As String, ByVal TempGrid As GridView)
HttpContext.Current.Response.Clear()
'HttpContext.Current.Response.Buffer = true;
HttpContext.Current.Response.Charset = "utf-8"
Dim Filename As String = Typename + ".xls"
HttpContext.Current.Response.AppendHeader("Content-Disposition", "online;filename=" + Filename)
HttpContext.Current.Response.ContentEncoding = System.Text.Encoding.GetEncoding("utf-8")
HttpContext.Current.Response.ContentType = "application/ms-excel"
'this.EnableViewState = false;
Dim oStringWriter As New System.IO.StringWriter()
Dim oHtmlTextWriter As New System.Web.UI.HtmlTextWriter(oStringWriter)
TempGrid.RenderControl(oHtmlTextWriter)
HttpContext.Current.Response.Write(oStringWriter.ToString())
HttpContext.Current.Response.End()
End Sub 'GenerateByGridView
...全文
136 6 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
ybyjcel 2012-02-14
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 net_lover 的回复:]


Public Overrides Sub VerifyRenderingInServerForm(control As Control)
End Sub
[/Quote]

孟老师利害是大家知道的,但最好运的是楼主遇到了。。。
孟子E章 2012-02-14
  • 打赏
  • 举报
回复
能不能转换成真正的EXCEL?
要实现真正的Excel,你需要使用Excel.Application进行实现,在Web方面很少这样做,
你还可以使用NPOI导出。
下载地址
http://npoi.codeplex.com/
在途中 2012-02-14
  • 打赏
  • 举报
回复
事情真的真多,哈哈!

今天在测试这功能时,又出现了问题,傲游3能正常下载,而傲游2却不能,出现了,点击按钮后,页面先被关掉,然后再弹出下载对话框,而且要下载的是Default.aspx页,这是怎么一回事呢?

想了好久,找了好久,只好上来再问一问了!
在途中 2012-02-13
  • 打赏
  • 举报
回复
首先谢谢net_lover(【孟子E章】),照他这样做后,后来又出现
“只能在执行 Render() 的过程中调用 RegisterForEventValidation”

我在 <%@ Page %> 中加入 EnableEventValidation="false"解决了问题,

后来又出现文件名乱码,我加入Filename = HttpUtility.UrlEncode(Filename, Encoding.UTF8)

现在总算能转换下来,但下载下来的文件可以用记事本打开,应该是网页形式的文本,只是这能用EXCEL打开罢了。

想再问问,是不是GiidView导出EXCEL才是这样?如果我用DATASET来导出数据,能不能转换成真正的EXCEL?
V-Far 2012-02-13
  • 打赏
  • 举报
回复
孟子真快...
上面就是解决办法
孟子E章 2012-02-13
  • 打赏
  • 举报
回复

Public Overrides Sub VerifyRenderingInServerForm(control As Control)
End Sub

62,242

社区成员

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

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

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

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