Manually Add Header in CsvHelper.CsvWriter

ぃ、小莉子 提交于 2019-12-06 21:20:01

问题


I'm using CsvHelper class to write rows in DataTable to a csv file. The code works but I can't get it to write the headers.

How can I add the headers manually without creating a Class Map?

http://joshclose.github.io/CsvHelper/

DataTable dt = GetDataTableFromDB();

System.IO.MemoryStream memoryStream = new System.IO.MemoryStream();
System.IO.StreamWriter streamWriter = new System.IO.StreamWriter( memoryStream );
CsvHelper.CsvWriter writer = new CsvHelper.CsvWriter( streamWriter );

foreach ( DataColumn column in properties.Columns )
    writer.WriteHeader( column.ColumnName );    //<--- How do I write to column

foreach ( DataRow row in dt.Rows )
{
    foreach ( object item in row.ItemArray )
        writer.WriteField( item.ToString() );

    writer.NextRecord();
}

回答1:


This is actually in the documentation under Writing to a CSV using a DataTable.

I'll put the code example here too.

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();
    }
}

Headers aren't anything special or different in a CSV file.




回答2:


The easiest way is to use

writer.WriteHeader<YourClass>();

More complete example:

using (StreamWriter sw = new StreamWriter(@"C:\output.csv"))
{
  using (CsvWriter writer = new CsvWriter(sw))
  {
     writer.WriteHeader<YourClass>();

     writer.WriteRecord(yourRecordVariable);
  }
}

As was posted here on Google groups by the author Josh Close.



来源:https://stackoverflow.com/questions/32443834/manually-add-header-in-csvhelper-csvwriter

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!