• 主页
  • ASP
  • .NET Framework
  • Web Services
  • VB
  • VC
  • 图表区
  • 分析与设计
  • 组件/控件开发
  • LINQ

导出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
...全文
71 点赞 收藏 6
写回复
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
回复 点赞
发动态
发帖子
.NET技术社区
创建于2007-09-28

4.9w+

社区成员

66.8w+

社区内容

.NET技术交流专区
社区公告
暂无公告