C# 효율적인 Excel 내보내기(IList - DataTable, DataSet)
7361 단어 Datatable
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
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
yui--datatable 행 추가 형식텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.