gpt4 book ai didi

.net - 数据表转CSV

转载 作者:行者123 更新时间:2023-12-03 21:40:04 25 4
gpt4 key购买 nike

这个问题与解析 CSV 无关。

使用以下代码从 DataTable 创建 CSV
但它很慢
100 行 x 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 不是这里的问题。
在 300 毫秒内从 0 到 100 万次加载 i
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());

最佳答案

有更快的方法来进行字符串连接和其他一些逻辑。使用字符串生成器来构建整个事情也可能是放缓的一部分。正如一些人所建议的那样,图书馆已经考虑了其中的一些事情,并且可能会执行得更快。

这是一些使用 CsvHelper 的代码(我写的)。

using( var dt = new DataTable() )
{
dt.Load( dataReader );
foreach( DataColumn column in dt.Columns )
{
csv.WriteField( column.ColumnName );
}
csv.NextRecord();

foreach( DataRow row in dt.Rows )
{
for( var i = 0; i < dt.Columns.Count; i++ )
{
csv.WriteField( row[i] );
}
csv.NextRecord();
}
}

如果您有 DataReader您甚至不必使用 DataTable那么,这也应该加快一些速度。
var hasHeaderBeenWritten = false;
while( dataReader.Read() )
{
if( !hasHeaderBeenWritten )
{
for( var i = 0; i < dataReader.FieldCount; i++ )
{
csv.WriteField( dataReader.GetName( i ) );
}
csv.NextRecord();
hasHeaderBeenWritten = true;
}

for( var i = 0; i < dataReader.FieldCount; i++ )
{
csv.WriteField( dataReader[i] );
}
csv.NextRecord();
}

关于.net - 数据表转CSV,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14882796/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com