DataGrid中的数据导入到Word和Excel_C#

王朝c#·作者佚名  2006-01-09
宽屏版  字体: |||超大  

using System;

using System.Collections;

using System.ComponentModel;

using System.Data;

using System.Drawing;

using System.Web;

using System.Web.SessionState;

using System.Web.UI;

using System.Web.UI.WebControls;

using System.Web.UI.HtmlControls;

using System.IO;

using System.Data.SqlClient ;

using System.Text;

namespace DataGrid_import_WordExcel

{

/// <summary>

/// 马亚红制作 2004-12-12

/// </summary>

public class WebForm1 : System.Web.UI.Page

{

protected System.Web.UI.WebControls.Button BtnImportWord;

protected System.Web.UI.WebControls.Button Btn_Import_Excel;

protected System.Web.UI.WebControls.DataGrid DataGrid1;

private void Page_Load(object sender, System.EventArgs e)

{

// 在此处放置用户代码以初始化页面

CreateDataSet();

}

#region Web 窗体设计器生成的代码

override protected void OnInit(EventArgs e)

{

//

// CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。

//

InitializeComponent();

base.OnInit(e);

}

/// <summary>

/// 设计器支持所需的方法 - 不要使用代码编辑器修改

/// 此方法的内容。

/// </summary>

private void InitializeComponent()

{

this.BtnImportWord.Click += new System.EventHandler(this.BtnImportWord_Click);

this.Btn_Import_Excel.Click += new System.EventHandler(this.Btn_Import_Excel_Click);

this.Load += new System.EventHandler(this.Page_Load);

}

#endregion

private void ExportDataGrid(string FileType, string FileName) //从DataGrid导出

{

Response.Charset = "GB2312";

Response.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312");

Response.AppendHeader("Content-Disposition", "attachment;filename=" +HttpUtility.UrlEncode(FileName,Encoding.UTF8).ToString());

Response.ContentType = FileType;

this.EnableViewState =false;

StringWriter tw = new StringWriter();

HtmlTextWriter hw =new HtmlTextWriter(tw);

DataGrid1.RenderControl(hw);

Response.Write(tw.ToString());

Response.End();

}

private void Btn_Import_Excel_Click(object sender, System.EventArgs e)

{

ExportDataGrid("application/ms-excel", "指数列表.xls"); //导到Excel

}

private void CreateDataSet() //建立DataSet

{

DataSet myDataSet = new DataSet("aNewDataSet");

DataTable table1 = MakeTable("ID", "Name");

myDataSet.Tables.Add(table1);

DataGrid1.DataSource=myDataSet;

DataGrid1.DataBind();

}

private DataTable MakeTable(String c1Name,String c2Name) //建表

{

int i;

DataTable myTable=new DataTable();

DataColumn myColumn;

// Add two DataColumns

myColumn = new DataColumn(c1Name,typeof(Int32)); //增加字段及设置类型

myTable.Columns.Add(myColumn);

myColumn = new DataColumn(c2Name,typeof(string));

myTable.Columns.Add(myColumn);

DataRow Dr;

for(i=1;i<11;i++) //表中增加数据

{

Dr=myTable.NewRow();

Dr[0]=i;

Dr[1]="Name" + i.ToString();

myTable.Rows.Add(Dr);

}

return myTable;

}

private void BtnImportWord_Click(object sender, System.EventArgs e) //导到Word

{

ExportDataGrid("application/ms-word", "指数列表.doc");

}

}

}

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
© 2005- 王朝网络 版权所有