C# 효율적인 Excel 내보내기(IList - DataTable, DataSet)

7361 단어 Datatable
마이크로소프트의 Excel 작업 클래스가 Excel을 내보내는 것은 매우 느릴 것이다. 이 방법은 간단하게 표의 내용을 문자열 형식으로 Excel에 기록하는 데 사용되는 기교 중 하나가 바로 "\t"이다.
C#의\t는 Tab 키에 해당하며 Excel에 쓸 때는 열과 열에 기록됩니다.
참조 네임스페이스:
using System.Drawing;

using System.Threading;

using System.IO;

using System.Data;

using System.Text;

using System.Collections;

 
protected void btnExport_Click(object sender, EventArgs e)

    {

        this.labPercent.Text = "";

        IList<ViewUserInfo> userList = viewUserInfoService.GetUserInfoListAll();

        DataTable dt = IListOut(userList);

        WriteExcel(dt, "d:\\a.xls");

    }

    #region  Excel

    public void WriteExcel(DataTable ds, string path)

    {

        long totalCount = ds.Rows.Count;

        Thread.Sleep(1000);

        long rowRead = 0;

        float percent = 0;



        StreamWriter sw = new StreamWriter(path, false, Encoding.GetEncoding("gb2312"));

        StringBuilder sb = new StringBuilder();

        for (int k = 0; k < ds.Columns.Count; k++)

        {

            sb.Append(ds.Columns[k].ColumnName.ToString() + "\t");

        }

        sb.Append(Environment.NewLine);

        for (int i = 0; i < ds.Rows.Count; i++)

        {

            //rowRead++;

            //percent = ((float)(100 * rowRead)) / totalCount;

            this.labPercent.Text ="<a href='UserInfo.xls' target='_blank'> </a>";

            for (int j = 0; j < ds.Columns.Count; j++)

            {

                sb.Append(ds.Rows[i][j].ToString() + "\t");

            }

            sb.Append(Environment.NewLine);

        }

        sw.Write(sb.ToString());

        sw.Flush();

        sw.Close();

    }

    public DataTable IListOut(IList<ViewUserInfo> ResList)

    {

        DataTable TempDT = new DataTable();



        // IList DataTable

        System.Reflection.PropertyInfo[] p = ResList[0].GetType().GetProperties();

        foreach (System.Reflection.PropertyInfo pi in p)

        {

            TempDT.Columns.Add(pi.Name, System.Type.GetType(pi.PropertyType.ToString()));

        }



        for (int i = 0; i < ResList.Count; i++)

        {

            ArrayList TempList = new ArrayList();

            // IList ArrayList

            foreach (System.Reflection.PropertyInfo pi in p)

            {

                object oo = pi.GetValue(ResList[i], null);

                TempList.Add(oo);

            }



            object[] itm = new object[p.Length];

            // ArrayList object[] 

            for (int j = 0; j < TempList.Count; j++)

            {

                itm.SetValue(TempList[j], j);

            }

            // object[] DataTable

            TempDT.LoadDataRow(itm, true);

        }

        // DataTable

        return TempDT;

    }

    



    #endregion

좋은 웹페이지 즐겨찾기