2014-02-06 149 views
0

我想将数据从数据表写入CSV文件,从C#中的Sheet 2开始。 请任何帮助。 我有以下功能来创建CSV文件。将数据写入csv文件单2

public void CreateCSVFile(DataTable dt, string strFilePath) 
{ 

     // Create the CSV file to which grid data will be exported. 
     StreamWriter sw = new StreamWriter(strFilePath, false); 
     // First we will write the headers. 
     //DataTable dt = m_dsProducts.Tables[0]; 
     int iColCount = dt.Columns.Count; 
     for (int i = 0; i < iColCount; i++) 
     { 
      sw.Write(dt.Columns[i]); 

      if (i < iColCount - 1) 
      { 
       sw.Write(","); 
      } 
     } 

     sw.Write(sw.NewLine); 
     // Now write all the rows. 
     foreach (DataRow dr in dt.Rows) 
     { 
      for (int i = 0; i < iColCount; i++) 
      { 
       if (!Convert.IsDBNull(dr[i])) 
       { 
        sw.Write(dr[i].ToString()); 
       } 
       if (i < iColCount - 1) 
       { 
        sw.Write(","); 
       } 
      } 
      sw.Write(sw.NewLine); 
     } 

     sw.Close(); 

    } 

回答

0

作为一个强烈的建议:不要试图发明自己的CSV作家/读者。这似乎很容易,但水中有龙,很多龙。特别是逃避的字符串很有趣 - 你如何管理一些行

逃脱这个瘦需要大量的工作。

因此,请继续使用库:http://kbcsv.codeplex.com/它是免费的,快速并节省您的工作时间。

作为进一步的问题:Sheet 2是Excel文件吗?

+0

感谢您的建议。 表2是csv表,因为你可以从excel打开csv。 有帮助吗? – user3258052

+0

啊你想保存到excel?比绝对使用epplus - 它甚至有一个方法来从数据库表中创建一个完整的文件。 –