用户控件上的GridView如何导入、导出到Excel表

时间:2022-06-12 09:26:52

在Baidu中一找"GridView导出到Excel"可以很顺利的找到我贴到下面的代码,很多人依照代码使用,发现以下几个问题:

(1)StringWriter 不能用,因为没有引入命名空间System.IO

(2)Encoding不能用,因为没有引入命名空间System.Text

(3)在用户控件上使用的GridView不能重写VerifyRenderingInServerForm函数。

 

一、GridView数据导出到Excel文件中

 1     protected void Button1_Click(object sender, EventArgs e)
 2     {
 3         Export("application/ms-excel""自命名文件名.xls");
 4     }
 5 
 6     private void Export(string FileType, string FileName)
 7     {
 8         Response.Charset = "GB2312";
 9         Response.ContentEncoding = System.Text.Encoding.UTF7;
10         Response.AppendHeader("Content-Disposition""attachment;filename=" + HttpUtility.UrlEncode    (FileName, Encoding.UTF8).ToString());
11         Response.ContentType = FileType;
12         this.EnableViewState = false;
13         StringWriter tw = new StringWriter();
14         HtmlTextWriter hw = new HtmlTextWriter(tw);
15         GridView1.RenderControl(hw);
16         Response.Write(tw.ToString());
17         Response.End();
18     }

19     //如果没有下面方法会报错类型“GridView”的控件“GridView1”必须放在具有 runat=server 的窗体标记内
20     public override void VerifyRenderingInServerForm(Control control)
21     {
22     }

 

二、Excel数据导入到GridView中

 1     //读取Excel数据的代码:这个很简单的
 2     private DataSet CreateDataSource()
 3     {
 4         string strCon;
 5         strCon = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + Server.MapPath("excel.xls"+ "; Extended Properties=Excel 8.0;";
 6         OleDbConnection olecon = new OleDbConnection(strCon);
 7         OleDbDataAdapter myda = new OleDbDataAdapter("SELECT * FROM [Sheet1$]", strCon);
 8         DataSet myds = new DataSet();
 9         myda.Fill(myds);
10         return myds;
11     }
12     protected void Button1_Click(object sender, EventArgs e)
13     {
14         GridView1.DataSource = CreateDataSource();
15         GridView1.DataBind();
16     }

 

【说明】

1、上面的例子网站上到处都有,我这里只是贴出来而已;

2、上述例子的代码是正确的,绝对没有语法错误;

3、但是,上面的代码只能是针对于GridView控件直接在aspx页面上,如果在用户控件上使用了GridView控件,那么你必须按照以下方式处理了

 

三、用户控件上的GridView如何导出到Excel表

1、前面步骤跟前面的一样,你需要一个按钮来处理导入/导出事件

2、你需要把用户控件放到某个页面上,如Test.aspx

3、如果你仅仅这样,页面肯定会报错。

4、为了避免错误,你必须在Test.aspx页面把第一行改成(红色为添加进去的)

<%@ Page Language="C#" EnableEventValidation = "false" AutoEventWireup="true" CodeFile="SysUser.aspx.cs" Inherits="Autho_SysUser2" %>

5、然后在Test.aspx.cs中重写
         public override void VerifyRenderingInServerForm(Control control)
       {

           //函数体内没有任何代码,切记
       }

6、浏览网页即可使用