繁体   English   中英

如何使用FileHelpers使用标头编写CSV文件?

[英]How do I write CSV file with header using FileHelpers?

我正在使用FileHelpers将DataTable内容写入CSV文件。

由于DataTable中有大量记录,我选择将结果集转储到CSV文件中,如下所示

CommonEngine.DataTableToCSV(dt, filename)

CSV已成功写入200万条大小为150MB的记录。

但我想在此CSV文件的第一行添加归档标题。

FileHelper是否允许使用CommonEngine.DataTableToCSV写入标头?

在调用WriteFile之前,必须使用engine.HeaderText = engine.GetFileHeader()

查看源代码,看起来没有办法设置标题行。 但是,复制代码并编写自己的替代品很容易。 像这样的东西:

public static void DataTableToCsv(DataTable dt, string filename, CsvOptions options, string headerLine)
{
    using (StreamWriter writer = new StreamWriter(filename, false, options.Encoding, 102400))
    {
        // output header
        writer.Write(headerLine);
        writer.Write(StringHelper.NewLine);

        foreach (DataRow row in dt.Rows)
        {
            object[] itemArray = row.ItemArray;
            for (int i = 0; i < itemArray.Length; i++)
            {
                if (i > 0)
                {
                    writer.Write(options.Delimiter);
                }
                writer.Write(options.ValueToString(itemArray[i]));
            }
            writer.Write(StringHelper.NewLine);
        }
        writer.Close();
    }
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM