Asp.net中DataTable導(dǎo)出到Excel的方法介紹_.Net教程
推薦:asp.net中倒計(jì)時(shí)自動(dòng)跳轉(zhuǎn)頁(yè)面的實(shí)現(xiàn)方法(使用javascript)本篇文章介紹了,asp.net中倒計(jì)時(shí)自動(dòng)跳轉(zhuǎn)頁(yè)面的實(shí)現(xiàn)方法(使用javascript)。需要的朋友參考下
#region DataTable導(dǎo)出到Excel
/// <summary>
/// DataTable導(dǎo)出到Excel
/// </summary>
/// <param name="pData">DataTable</param>
/// <param name="pFileName">導(dǎo)出文件名</param>
/// <param name="pHeader">導(dǎo)出標(biāo)題以|分割</param>
public static void DataTableExcel(System.Data.DataTable pData, string pFileName, string pHeader)
{
System.Web.UI.WebControls.DataGrid dgExport = null;
// 當(dāng)前對(duì)話
System.Web.HttpContext curContext = System.Web.HttpContext.Current;
// IO用于導(dǎo)出并返回excel文件
System.IO.StringWriter strWriter = null;
System.Web.UI.HtmlTextWriter htmlWriter = null;
if (pData != null)
{
string UserAgent = curContext.Request.ServerVariables["http_user_agent"].ToLower();
if (UserAgent.IndexOf("firefox") == -1)//火狐瀏覽器
pFileName = HttpUtility.UrlEncode(pFileName, System.Text.Encoding.UTF8);
curContext.Response.AddHeader("Content-Disposition", "attachment; filename=" + pFileName + ".xls");
curContext.Response.ContentType = "application/vnd.ms-excel";
strWriter = new System.IO.StringWriter();
htmlWriter = new System.Web.UI.HtmlTextWriter(strWriter);
// 為了解決dgData中可能進(jìn)行了分頁(yè)的情況,需要重新定義一個(gè)無(wú)分頁(yè)的DataGrid
dgExport = new System.Web.UI.WebControls.DataGrid();
dgExport.DataSource = pData.DefaultView;
dgExport.AllowPaging = false;
dgExport.ShowHeader = false;//去掉標(biāo)題
dgExport.DataBind();
string[] arrHeader = pHeader.Split('|');
string strHeader = "<table border=\"1\" style=\"background-color:Gray;font-weight:bold;\"><tr>";
foreach (string j in arrHeader)
{
strHeader += "<td>" + j.ToString() + "</td>";
}
strHeader += "</tr></table>";
// 返回客戶端
dgExport.RenderControl(htmlWriter);
string strMeta = "<meta http-equiv=\"content-type\" content=\"application/ms-excel; charset=UTF-8\"/>";
curContext.Response.Write(strMeta + strHeader + strWriter.ToString());
curContext.Response.End();
}
}
#endregion
分享:.NET 線程基礎(chǔ)的使用介紹本篇文章介紹了,.NET 線程基礎(chǔ)的使用說(shuō)明,需要的朋友參考下
- asp.net如何得到GRIDVIEW中某行某列值的方法
- .net SMTP發(fā)送Email實(shí)例(可帶附件)
- js實(shí)現(xiàn)廣告漂浮效果的小例子
- asp.net Repeater 數(shù)據(jù)綁定的具體實(shí)現(xiàn)
- Asp.Net 無(wú)刷新文件上傳并顯示進(jìn)度條的實(shí)現(xiàn)方法及思路
- Asp.net獲取客戶端IP常見(jiàn)代碼存在的偽造IP問(wèn)題探討
- VS2010 水晶報(bào)表的使用方法
- ASP.NET中操作SQL數(shù)據(jù)庫(kù)(連接字符串的配置及獲取)
- asp.net頁(yè)面?zhèn)髦禍y(cè)試實(shí)例代碼
- DataGridView - DataGridViewCheckBoxCell的使用介紹
- asp.net中javascript的引用(直接引入和間接引入)
- 三層+存儲(chǔ)過(guò)程實(shí)現(xiàn)分頁(yè)示例代碼
.Net教程Rss訂閱編程教程搜索
.Net教程推薦
- 關(guān)于ASP.NET在IIS一些問(wèn)題的經(jīng)驗(yàn)總結(jié)
- asp.net中文件下載功能的實(shí)例代碼
- 菜鳥(niǎo)也學(xué)習(xí)ASP.NET如何讀取數(shù)據(jù)庫(kù)內(nèi)容
- JSP和ASP.NET存儲(chǔ)過(guò)程的對(duì)比
- ASP.NET 2.0控件異步回調(diào)
- 解析.NET中的XmlReader與XmlWriter
- ADO.NET實(shí)用經(jīng)驗(yàn)無(wú)保留曝光
- ASP.NET立即上手教程(2)
- 解讀Asp.net中過(guò)濾html,js,css代碼的方法
- asp.net Repeater 數(shù)據(jù)綁定的具體實(shí)現(xiàn)
- 相關(guān)鏈接:
- 教程說(shuō)明:
.Net教程-Asp.net中DataTable導(dǎo)出到Excel的方法介紹
。