Asp.net匯出到Excel

來源:互聯網
上載者:User

Asp.net匯出到Excel 的問題已經是老生常談了,今天忽然用到,感覺以前寫的有點亂,就順手封裝了一下,貼出代碼,僅供參考

 

using System;
using System.Collections.Generic;
using System.IO;
using System.Text;
using System.Web;
using System.Data;

namespace AK.T.FileDeal
{
    public class Excel
    {

    /// <summary>
        /// 匯出到Excel titile為excel的頭部,datatable欄位必須和title向對應
        /// </summary>
        /// <param name="ds"></param>
        /// <param name="title"></param>
        public void CreateExcel(DataTable ds, string[] title, System.Web.UI.Page page)
        {
            HttpResponse resp;
            resp = page.Response;
            resp.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312");
            resp.AppendHeader("Content-Disposition", "attachment;filename=Cards_" + DateTime.Now.ToShortDateString() + ".xls");

            string ls_item = "";
            string colHeaders = "";
            DataTable dt = ds;
            DataRow[] myRow = dt.Select("");

            for (int i = 0; i < title.Length; i++)
            {
                if (i == title.Length - 1)
                {
                    colHeaders += title[i] + "\n";
                    continue;
                }
                colHeaders += title[i] + "\t";
            }

           int count = title.Length;

            foreach (DataRow row in myRow)
            {
                for (int i = 0; i < count; i++)
                {
                    if (i == count - 1)
                    {
                        ls_item += row[i].ToString() + "\n";
                        continue;
                    }
                    ls_item += row[i].ToString() + "\t";
                }
            }
            resp.Write(colHeaders + ls_item);
            resp.End();
        }

        /// <summary>
        ///  匯出到Excel titile為excel的頭部,DtRow為ds中欄位的名稱
        /// </summary>
        /// <param name="ds"></param>
        /// <param name="title"></param>
        /// <param name="DtRow"></param>
        public void CreateExcel(DataTable ds, string[] title, string[] DtRow, System.Web.UI.Page page)
        {
            if (DtRow.Length != ds.Rows.Count)
            {
                return;
            }
            HttpResponse resp;
            resp = page.Response;
            resp.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312");
            resp.AppendHeader("Content-Disposition", "attachment;filename=Cards_" + DateTime.Now.ToShortDateString() + ".xls");

            string ls_item = "";
            string colHeaders = "";
            DataTable dt = ds;
            DataRow[] myRow = dt.Select("");

            for (int i = 0; i < title.Length; i++)
            {
                if (i == title.Length - 1)
                {
                    colHeaders += title[i] + "\n";
                    continue;
                }
                colHeaders += title[i] + "\t";
            }
            foreach (DataRow row in myRow)
            {
                for (int i = 0; i < DtRow.Length; i++)
                {
                    if (i == DtRow.Length - 1)
                    {
                        ls_item += row[DtRow[i]].ToString() + "\n";
                        continue;
                    }
                    ls_item += row[DtRow[i]].ToString() + "\t";
                }
            }
            resp.Write(colHeaders + ls_item);
            resp.End();
        }

        /// <summary>
        /// 單行資料匯出
        /// </summary>
        /// <param name="title"></param>
        /// <param name="Content"></param>
        public void CreateOnceExcel(string[] title, string[] Content, System.Web.UI.Page page)
        {
            HttpResponse resp;
            resp = page.Response;
            resp.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312");
            resp.AppendHeader("Content-Disposition", "attachment;filename=Cards_" + DateTime.Now.ToShortDateString() + ".xls");

            string ls_item = "";
            string colHeaders = "";

            for (int i = 0; i < title.Length; i++)
            {
                if (i == title.Length - 1)
                {
                    colHeaders += title[i] + "\n";
                    continue;
                }
                colHeaders += title[i] + "\t";
            }
            for (int i = 0; i < Content.Length; i++)
            {
                if (i == Content.Length - 1)
                {
                    ls_item += Content[i].ToString() + "\n";
                    continue;
                }
                ls_item += Content[i].ToString() + "\t";
            }

            resp.Write(colHeaders + ls_item);
            resp.End();
        }

    }
}

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.