您的位置:首页 > 编程语言 > C#

转载——c# 大批量数据导出到excel[此为个人分享] [问题点数:20分,结帖人rocket2010]

2013-04-30 11:37 405 查看
我的方法不是使用微软的excel操作类,因为那种实在爆慢,一个个单元格循环写,实在太慢了。【不信朋友们可以试试】

而使用io写的话 半分钟都不用

我数据库数据量为:120000行 29列

技术要点:1.使用的是StreamWriter sw = new StreamWriter(path, false,Encoding.GetEncoding("gb2312"));最终生成文件

2.使用 StringBuilder sb = new StringBuilder();类把查询出来的数据组合为一句超长字符串一次性插入到excel中,

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

注意,可不能漏了"\t" 这个是非常重要的! 因为c# "\t"就等于 键盘上的Tab [朋友们可以试试:打开新的txt然后输入1按Tab,输入2按Tab,输入3按Tab保存,然后打开excel文件 把刚刚保存的txt文件拉进去打开你就发现原来。这样写的话1 2 3 会分别在每个单元格上的了。所以上面才使用 "\t"连起来数据库出来的那堆数据,这样一次性导进去,他们就会按照每个单元格来填充!]

需要引用:

using System.Threading;

using System.IO;

方法如下:

C# code

?
这是从高手的博客中转载过来的,当时正好碰到大量数据导入EXCEL速度慢的难题,这篇文字看了感觉就像神来之笔,我的问题被这篇文章迎刃而解了,遂转载之、收藏之。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐