ps.註解的部分屬於儲存檔案的程式碼
excel.aspx
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="excel.aspx.cs" Inherits="excel" %>
02
03 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "
http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
04 <html xmlns="
http://www.w3.org/1999/xhtml">
05 <head id="Head1" runat="server">
06 <title>未命名頁面</title>
07 </head>
08 <body>
09 <form id="form1" runat="server">
10 <div>
<asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" DataSourceID="SqlDataSource1">
<Columns>
<asp:BoundField DataField="id" HeaderText="id" InsertVisible="False" ReadOnly="True"
SortExpression="id" />
<asp:BoundField DataField="gender" HeaderText="gender" SortExpression="gender" />
</Columns>
</asp:GridView>
<asp:Button ID="ExportExcel" runat="server" Text="匯出Excel檔/儲存Excel檔" OnClick="ExportExcel_Click"
Width="200px" /><br />
<asp:Button ID="ExportWord" runat="server" Text="匯出Word檔/儲存Word檔" OnClick="ExportWord_Click"
Width="200px" /><br />
<asp:Button ID="ExportText" runat="server" Text="匯出txt檔/儲存txt檔" Width="200px" OnClick="ExportText_Click" />
<asp:SqlDataSource ID="SqlDataSource1" runat="server"
ConnectionString="<%$ ConnectionStrings:DatabaseConnectionString
%>"
SelectCommand="SELECT * FROM [user]"></asp:SqlDataSource>
</div>
</form>
</body>
</html>
excel.aspx.cs
using ...System;
using System.Data;
using System.Configuration;
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using System.Text;
using System.IO;
public partial class excel : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
}
protected void ExportExcel_Click(object sender, EventArgs e)
{
//匯出excel檔
Response.Clear();
Response.AddHeader("content-disposition", "attachment;filename=test.xls");//excel檔名
Response.ContentType = "application/vnd.ms-excel";
Response.Charset = "";
System.IO.StringWriter sw = new System.IO.StringWriter();
System.Web.UI.HtmlTextWriter htw = new System.Web.UI.HtmlTextWriter(sw);
DataGrid dg = new DataGrid();
dg.DataSource = this.SqlDataSource1.Select(DataSourceSelectArguments.Empty);
dg.DataBind();
dg.RenderControl(htw);
Response.Write(sw.ToString());
Response.End();
//儲存excel檔
//System.IO.StringWriter sw = new System.IO.StringWriter();
//System.Web.UI.HtmlTextWriter htw = new System.Web.UI.HtmlTextWriter(sw);
//DataGrid dg = new DataGrid();
//dg.DataSource = this.SqlDataSource1.Select(DataSourceSelectArguments.Empty);
//dg.DataBind();
//dg.RenderControl(htw);
//System.IO.File.WriteAllText(@"c:/test.xls", sw.ToString());
}
protected void ExportWord_Click(object sender, EventArgs e)
{
//匯出word檔
Response.Clear();
Response.AddHeader("content-disposition", "attachment;filename=test.doc");//word檔名
Response.ContentType = "application/vnd.ms-word";
Response.Charset = "";
System.IO.StringWriter sw = new System.IO.StringWriter();
System.Web.UI.HtmlTextWriter htw = new System.Web.UI.HtmlTextWriter(sw);
DataGrid dg = new DataGrid();
dg.DataSource = this.SqlDataSource1.Select(DataSourceSelectArguments.Empty);
dg.DataBind();
dg.RenderControl(htw);
Response.Write(sw.ToString());
Response.End();
//儲存word檔
//System.IO.StringWriter sw = new System.IO.StringWriter();
//System.Web.UI.HtmlTextWriter htw = new System.Web.UI.HtmlTextWriter(sw);
//DataGrid dg = new DataGrid();
//dg.DataSource = this.SqlDataSource1.Select(DataSourceSelectArguments.Empty);
//dg.DataBind();
//dg.RenderControl(htw);
//System.IO.File.WriteAllText(@"c:/test.doc", sw.ToString());
}
protected void ExportText_Click(object sender, EventArgs e)
{
//匯出txt檔
Response.Clear();
Response.AddHeader("content-disposition", "attachment;filename=test.txt");//txt檔名
Response.ContentType = "application/vnd.ms-word";
Response.Charset = "";
System.Text.StringBuilder sb = new System.Text.StringBuilder();
DataTable dt = new DataTable();
dt = ((DataView)this.SqlDataSource1.Select(DataSourceSelectArguments.Empty)).ToTable();
//欄位名
for (int i = 0; i < dt.Columns.Count; i++)
{
sb.Append(dt.Columns[i].ColumnName);
sb.Append(",");
}
sb.Append(Environment.NewLine);
//資料
for (int i = 0; i < dt.Rows.Count; i++)
{
for (int j = 0; j < dt.Columns.Count; j++)
{
sb.Append(dt.Rows[i][j].ToString());
sb.Append(",");
}
sb.Append(Environment.NewLine);
}
Response.Write(sb.ToString());
Response.End();
//儲存txt檔
//System.Text.StringBuilder sb = new System.Text.StringBuilder();
//DataTable dt = new DataTable();
//dt = ((DataView)this.SqlDataSource1.Select(DataSourceSelectArguments.Empty)).ToTable();
////欄位名
//for (int i = 0; i < dt.Columns.Count; i++)
//...{
// sb.Append(dt.Columns[i].ColumnName);
// sb.Append(",");
//}
//sb.Append(Environment.NewLine);
////資料
//for (int i = 0; i < dt.Rows.Count; i++)
//...{
// for (int j = 0; j < dt.Columns.Count; j++)
// ...{
// sb.Append(dt.Rows[i][j].ToString());
// sb.Append(",");
// }
// sb.Append(Environment.NewLine);
//}
//System.IO.File.WriteAllText(@"c:/test.txt", sb.ToString());
}
protected void Button3_Click(object sender, EventArgs e)
{
//Export("application/ms-excel", "报表.xls");//输出Excel
Export("application/ms-powerpnt", "报表.ppt"); //输出Powerpoint
}
}
分享到:
相关推荐
asp.net 导出GridView里的数据到Excel中
asp.net Gridview Export PDF,Word,Excel,Csv等等(GridView导出为Excel,word,pdf,csv)源代码 C#,VB.NET
asp.net GridView导出excel.rar
ASP.NET实现Gridview隐藏/显示列源码 介绍: 这篇文章演示如果让用户有显示/隐藏他们需要的GridView的列的功能,这是非常有用的,因为在GridView的所有列并不是每个的用户都需要的.用户想根据自己的需求看到想要的...
ASP.NET中把Gridview导出为EXCEL,解决中文乱码问题,详情请看视频
Gridview中的内容导出到Excel 将gridview的内容导出到excel中去 解决gridview的excel导出问题
ASP.net GridView双击事件,弹出一个窗口显示详细信息,模式窗口显示详细信息。
ASp.NET GridView 编辑模板ASp.NET GridView 编辑模板
用户可通过:http://www.jquerybyexample.net/2013/07/jquery-gridview-aspnet-tips-and-tricks.html 下载 Formatting Related Formatting ASP.NET GridView using jQuery Highlight row on mouseover in ...
ASP.NET GridView中两种全选方法.txt
一个漂亮的GridView CSS 模板样式。 测试过,可用。
Asp.net GridView标题列可拖动调整宽度效果实现,实现效果类似于Winform中的ListView控件拖动标题,必变列宽,但界面与listview控件不一样,需要自己改变gridivew样式,具体是根据js插件实现;
ASP.NET GridView表格列宽拖动功能示例,很值得一看!
文章: http://blog.csdn.net/yysyangyangyangshan/article/details/38807287 asp.net gridview 复杂 复合 表头
Asp.net gridview 的样式
ASP.NET从GridView输出Word,Excel,Powerpoint
asp.net GridView导出到Excel代码,需要的朋友可以参考下。
ASP.NET固定GridView表头_SuperTables