此问题与解析CSV无关。DataTable To CSV
使用下面的代码创建从一个DataTable
一个CSV,但它是缓慢
100行14列是4秒
有一个更快的方法?
StringBuilder sb = new StringBuilder();
bool first = true;
int colCount = 0;
foreach (DataColumn dc in DT.Columns)
{
if (first) first = false; else sb.Append(",");
sb.Append("\"" + dc.ColumnName + "\"");
colCount++;
}
sb.AppendLine();
foreach (DataRow dr in DT.Rows)
{
first = true;
for (int i = 0; i < colCount; i++)
{
if (first) first = false; else sb.Append(",");
sb.Append("\"" + dr[i].ToString().Trim() + "\"");
}
sb.AppendLine();
}
return sb.ToString();
StringBuilder在这里不是问题。
负载i从0到100万的运行在300毫秒
StringBuilder sb = new StringBuilder();
Stopwatch sw = new Stopwatch();
sw.Start();
for (int i = 0; i < 1000000; i++)
{
sb.Append(i.ToString());
}
sw.Stop();
Debug.Write(sw.ElapsedMilliseconds.ToString());
可能重复(http://stackoverflow.com/questions/9642055/csv-parsing-options-with-net) – 2013-02-14 19:48:39
@DourHighArch的问题是创造一个CSV。不解析。这个问题没有关于解析CSV的问题。 – Paparazzi 2013-02-14 20:09:01
我唯一的意见是你正在将你的输出写入一个StringBuilder - 为什么不直接写入一个流呢? – Matt 2013-02-14 20:31:35