博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
C#高效导出Excel(IList转DataTable,DataSet)
阅读量:6310 次
发布时间:2019-06-22

本文共 2597 字,大约阅读时间需要 8 分钟。

微软的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
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 ="
此处下载"; 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
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

 

转载于:https://www.cnblogs.com/qqflying/archive/2013/05/19/3087229.html

你可能感兴趣的文章
简单的一条SQL,不简单的做事思维 NOT IN 、NOT EXISTS、LEFT JOIN用法差别 ...
查看>>
DataWorks:任务未运行自助排查
查看>>
ionic/cordova热部署
查看>>
「镁客早报」特斯拉裁员,马斯克解释没有办法;微软推出Azure DevOps赏金计划...
查看>>
centos 7.4 使用 pgxc_ctl 安装与使用
查看>>
Redis 单key值过大 优化方式
查看>>
【数据库】表分区
查看>>
nutz-sqltpl 1.3.4.RELEASE 发布,在 Nutz 项目中“解决 Java 拼接 SQL”问题
查看>>
城市 | 800个地铁站数据透析的京沪白领图鉴:隐形土豪、无产中产阶级和猪猪女孩...
查看>>
前端脚本!网站图片素材中文转英文
查看>>
linux的常用易忘命令
查看>>
PHP 分割字符串
查看>>
java 基于QRCode、zxing 的二维码生成与解析
查看>>
关于职业规划的一些思考
查看>>
img垂直水平居中与div
查看>>
Fabrik – 在浏览器中协作构建,可视化,设计神经网络
查看>>
防恶意注册的思考
查看>>
http2-head compression
查看>>
C# 命名空间
查看>>
订餐系统之同步美团商家订单
查看>>