用户控件上的GridView如何导入、导出到Excel表
2008-10-26 15:42
363 查看
在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、浏览网页即可使用
(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、浏览网页即可使用
相关文章推荐
- 用户控件上的GridView如何导入、导出到Excel表
- 关于EXCEL表如何导入进DataGridView控件中的问题
- C#WinFrom DEV控件Gridview导入导出Excel
- expdp/impdp如何实现不同用户之间的导出导入
- ASP.NET中导出的伪Excel表,如何再导入到ASP中呢?
- Execl表格中的数据导入到GridView控件中并导出打印
- GridView导入导出Excel表
- 如何将Windows Server域(AD活动目录)中的用户导出并导入至Outlook2010通讯簿
- 如何导入excel数据到SQL server数据库 & 如何导出GridView数据至Excel
- 如何使用POI对Excel表进行导入和导出
- 如何将Windows Server域(AD活动目录)中的用户导出并导入至Outlook2010通讯簿
- 如何将GridView控件数据导出到word和Excel
- 如何用expdp、impdp按表空间导出、导入?
- ASP.NET 2.0,C#----利用GridView控件导出其他文件(导出Excel,导出Word文件)
- oracle创建数据库表空间 用户 授权 导入 导出数据库
- Oracle创建删除用户、角色、表空间、导入导出、...命令总结
- 如何导入导出大数据量(1000万条)的表?
- Oracle创建删除用户、角色、表空间、导入导出、...命令总结
- Oracle创建删除用户、角色、表空间、导入导出数据库命令行方式总结
- Oracle创建用户、表空间、导入导出、...命令