zoukankan      html  css  js  c++  java
  • Control 'GridView1' of type 'GridView' must be placed inside a form tag with runat=server

    这里总结了一下比较常用的服务器控件导出成excel报表的经验与大家分享: 以前做excel报表导出的时候是自己一个一个地画表格,然后将数据组装,再用微软的excel组件来输出excel文件。 字段少还没关系,字段多了,一个一个地去拼,数据要一一对应,我的那个天啊! 俗话说“不会偷懒的程序员,不是一个好的程序员”,程序员就是为了那些懒人来服务滴(纯属个人总结,如有雷同,均出自此处)!所以要想尽各种办法来偷懒,那有没有好的办法,我在页面上看到什么,就一次性全部导出成excel文件呢?包括样式?毫无一问,回答当然是肯定的,要不要不会写这个总结了。。 OK,闲话少说,直接帖代码算了: 比较常用滴: grideview报表导出:

    protected void Button1_Click(object sender, EventArgs e)         {             DataSet ds = new DataSet();             ds.ReadXml(AppDomain.CurrentDomain.BaseDirectory + "XMLFile1.xml");             GridView1.DataSource = ds;             GridView1.DataBind();

                Response.Clear();             Response.AddHeader("content-disposition", "attachment;filename=TaoBaoItems.xls");             Response.Charset = "gb2312";             Response.ContentType = "application/vnd.xls";             System.IO.StringWriter stringWrite = new System.IO.StringWriter();             System.Web.UI.HtmlTextWriter htmlWrite = new HtmlTextWriter(stringWrite);             EnableViewState = false;             GridView1.RenderControl(htmlWrite);

                Response.Write(stringWrite.ToString());             Response.End();         }

    如果你这样做了,你会得到一个很郁闷的错误提示:

    Control 'GridView1' of type 'GridView' must be placed inside a form tag with runat=server.

    解决这个的办法有一个: public override void VerifyRenderingInServerForm(Control control)         {         } 加上上面这个重写的代码后,就能保存为excel文件了,是不是很爽啊? 那么不这样写可不可以呢? 回答当然也是肯定的: 办法就是: 不要使用gridview这个东东来绑定数据,用大伙比较喜欢的:Repeater控件来绑定程序! 代码还是一样滴: Code: protected void Button1_Click(object sender, EventArgs e)         {

    DataSet ds = new DataSet();             ds.ReadXml(AppDomain.CurrentDomain.BaseDirectory + "XMLFile1.xml");             GridView1.DataSource = ds;             GridView1.DataBind();

                Response.Clear();             Response.AddHeader("content-disposition", "attachment;filename=TaoBaoItems.xls");             Response.Charset = "gb2312";             Response.ContentType = "application/vnd.xls";             System.IO.StringWriter stringWrite = new System.IO.StringWriter();             System.Web.UI.HtmlTextWriter htmlWrite = new HtmlTextWriter(stringWrite);             EnableViewState = false;             GridView1.RenderControl(htmlWrite);

                Response.Write(stringWrite.ToString());             Response.End(); } HTML:

    <asp:Repeater ID="Repeater1" runat="server"> <HeaderTemplate> <table> <tr><td>姓名</td><td>年龄</td></tr> </HeaderTemplate> <ItemTemplate> <tr><td><%#Eval("name")%></td><td><%#Eval("age")%></td></tr> </ItemTemplate> <FooterTemplate> </table> </FooterTemplate> </asp:Repeater> <asp:Button ID="Button1" runat="server" onclick="Button1_Click" Text="Button" />

    这样导出成excel报表就没问题了。 其实有时候你会发现,如果你导出来的表格出现了乱码,这就很郁闷了,年龄列的表头名字为:“骞撮緞”,这是个什么编码? 我又不是神仙,我怎么知道,于是又想了个办法,代码如下:         static void Main(string[] args)         {             string sttest = "骞撮緞";             EncodingInfo[] infoList=Encoding.GetEncodings();             foreach (EncodingInfo encode in infoList)             {                 byte[] buffer1 = encode.GetEncoding().GetBytes(sttest);                 string strBuffer = Encoding.UTF8.GetString(buffer1);                 Console.WriteLine("Encoding={0},编码为:{1}", encode.Name.ToString(), strBuffer);             } } 乖乖啊,乱码一大堆,不过如黑暗中见一丝曙光,有几个是“年龄”,于是挑了一个比较熟悉的编码:“GB18030”,于是将代码改成如下:

    protected void Button1_Click(object sender, EventArgs e)         {             Response.AddHeader("content-disposition", "attachment;filename=TaoBaoItems.xls"); //网站编码             Response.Charset = "utf-8"; //输出编码             Response.ContentEncoding = System.Text.Encoding.GetEncoding("GB18030");             Response.ContentType = "application/vnd.xls";             System.IO.StringWriter stringWrite = new System.IO.StringWriter();             System.Web.UI.HtmlTextWriter htmlWrite = new HtmlTextWriter(stringWrite);                         Repeater1.RenderControl(htmlWrite);

                Response.Write(stringWrite.ToString());             Response.End();         }

    OK,一切搞定了,这个世界终于安静下来了! 从此以后,大伙导出excel就是成事不求人了!
    ---http://www.cnblogs.com/bbqqqbq/

    Export GridView To Excel

    方法一: 用foreach DataTable中的每一個Row,再Response.Write成CSV; 方法二: 寫成Reporting Service報表,借重它輸出成Excel功能。 但這二個方法都有些缺點,前者會因為轉成CSV會喪失格式設計,後者則得在做好DataGrid/GridView後,再另外做一張報表並建立Reporting Service機制,同時,二者都得在GridView/DataGrid外多花功夫。

    利用GridView自行Render出與網頁上格式相同的HTML,配合application/vnd.xls MIME Type,GridView就可以直接在Excel中重現 protected void btnExportExcel_Click(object sender, EventArgs e) { Response.Clear(); Response.AddHeader("content-disposition", "attachment;filename=PoolExport.xls"); Response.ContentType = "application/vnd.xls"; System.IO.StringWriter sw = new System.IO.StringWriter(); System.Web.UI.HtmlTextWriter htw = new HtmlTextWriter(sw); //關閉換頁跟排序 GridView1.AllowSorting = false; GridView1.AllowPaging = false; //移去不要的欄位 GridView1.Columns.RemoveAt(GridView1.Columns.Count - 1); GridView1.DataBind(); //建立假HtmlForm避免以下錯誤 //Control 'GridView1' of type 'GridView' must be placed inside //a form tag with runat=server. //另一種做法是override VerifyRenderingInServerForm後不做任何事 //這樣就可以直接GridView1.RenderControl(htw); HtmlForm hf = new HtmlForm(); Controls.Add(hf); hf.Controls.Add(GridView1); hf.RenderControl(htw); Response.Write(sw.ToString()); Response.End(); }

    補充說明幾個重點: 1.由於是透過HTML+MIME宣告的原理,DataGrid、GridView都適用。 2.記得移去不要的欄位,取消排序、分頁的設定。 3.這個寫法會產生Control 'GridView1' of type 'GridView' must be placed inside a form tag with runat=server的錯誤,可利用override VerifyRenderingInServerForm或另建一個假的HtmlForm來避免 解決方法1. 若查詢結果含有排序功能所以存成 Excel 時要先關閉 AllowSorting 功能(不然會有連結),然後需要再 DataBind 一次。 而在 DataBind 之前使用 EnableViewState = false; 即可避免「Control 'GridView1' of type 'GridView' must be placed inside a form tag with runat=server. 」的錯誤 解決方法2. 只要加上 public override void VerifyRenderingInServerForm(Control control) { //避免「型別 xxx 的控制項 xxx 必須置於有 runat=server 的表單標記之中。」的問題 } 即可 4.這個寫法還會導致RegisterForEventValidation can only be called during Render()的錯誤,需在Page宣告中停用EnableEventValidation解決。 5. 這種產生HTML再標ContentType的方法只能產生單一Sheet 6. 匯出的Excel可以開啟 可是會出現檔案格式與附檔名格式不同的訊息這個警示

    資料來源:http://blog.darkthread.net/blogs/darkthreadtw/archive/2009/12/06/1143.aspx
    http://blog.sina.com.cn/s/blog_6d4576c70100m6n4.html

  • 相关阅读:
    HDU 4772 Zhuge Liang's Password (矩阵旋转)
    POJ 1141 Brackets Sequence(区间DP)
    POJ 2531 Network Saboteur (DFS)
    HDU 2680 Choose the best route (最短路)
    HDU 1285 确定比赛名次 (预处理+拓扑排序)
    HDU 4540 威威猫系列故事——打地鼠 (DP)
    HDU 2899 Strange fuction (二分)
    HDU 3485 Count 101(DP)
    codeforces 510c (拓扑排序)
    codeforces 510B Fox And Two Dots(dfs)
  • 原文地址:https://www.cnblogs.com/dennys/p/3092861.html
Copyright © 2011-2022 走看看