使用ASP.NET的GridView导出/儲存資料至Excel,Word,Txt檔,Powerpoint

news/2024/7/21 4:20:08 标签: excel, powerpoint, asp.net, datagrid, server, object
 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
      }

}

 

http://www.niftyadmin.cn/n/1412637.html

相关文章

操作系统第五章:1、I/O管理

I/O控制方式 缓冲技术 &#xff08;1&#xff09;单缓冲 &#xff08;2&#xff09;双缓冲 &#xff08;3&#xff09;环形缓冲 I/O性能问题 同步&#xff1a;执行一个操作之后&#xff0c;进程触发IO操作并等待(也就是我们说的阻塞)或者轮询的去查看IO操作(也就是我们说…

网页中添加播放器播放视频文件与网页增加背景音乐示例

一.在网页中播放视频文件&#xff0c;以下代码是播放器&#xff0c;再加入如【☆☆动作-欧美-虎胆龙威4-原创02.dvd.rm】电影&#xff0c;打开即可播放了&#xff01; <html><head><title>无标题文档</title><meta http-equiv"Content-Type&qu…

ubuntu不能正常使用make menuconfig的解决方案

so easy sudo apt-get install build-essentialsudo apt-get install libncurses5sudo apt-get install libncurses5-dev happy当然有的时候在执行以上命令的时候会出错&#xff0c;提示要更新“软件列表”&#xff0c;OK&#xff0c;乖乖的先更新再执行以上命令吧。更新命令 s…

day56-1 select的问题以及epoll的使用

select的问题 当进程被唤醒时&#xff0c;不清楚到底哪个socket有数据&#xff0c;只能遍历一遍每一次select的执行&#xff0c;都需要将这进程&#xff0c;再加入到等待队列中为了重复添加等待队列&#xff0c;当每一次操作完成时&#xff0c;也需要从等待队列中删除进程所以s…

操作系统第五章:2、磁盘管理

基本概念 对于磁盘&#xff0c;每个磁道的扇区数并不是常量。绝大多数磁盘都有一些缺陷扇区&#xff0c;因此映射必须用磁盘上的其他空闲扇区来替代这些缺陷扇区。 磁盘缺陷 &#xff30;表&#xff1a;又称为永久缺陷列表&#xff0c;用于记录硬盘生产过程中产生的缺陷。 G表…

多文件上传与简单操作文件上传实例(文件上传,自动重命名,自动添加文件夹)

一.多文件上传【客户端处理脚本的例子】 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"><HTML><HEAD><meta http-equiv"Content-Language"content"zh-cn"><script>...function mCreateFile(obj…

iOS 10 的适配问题-b

随着iOS10发布的临近,大家的App都需要适配iOS10,下面是我总结的一些关于iOS10适配方面的问题,如果有错误,欢迎指出. 1.系统判断方法失效: 在你的项目中,当需要判断系统版本的话,不要使用下面的方法: #define isiOS10 ([[[[UIDevice currentDevice] systemVersion] substringToI…

windows上安装MySQL数据库

目录 Windows上安装MySQL简单的使用步骤正确的运行方式MySQL配置文件初始化数据库命令注意5.7版本需要初始化data目录Windows上安装MySQL windows上安装MySQL较为简单&#xff0c;点击链接https://dev.mysql.com/downloads/mysql/&#xff0c;但不要下载最新的版本&#xff0c;…