当从visual studio导出到csv c时,Streamwriter会随机添加额外的换行符#

时间:2016-10-19 13:22:34

标签: c# excel visual-studio csv streamwriter

我已经尝试了一段时间,在数据记录后将数据表导出到visual studio中的csv。

出于某种原因,我在导入excel时会得到奇怪的结果,而记事本很好。似乎在数据中的随机点添加了换行符。

我已经争取了一段时间,所以任何帮助都表示赞赏!

Excel Version

Notepad Version

void SaveAllData()
    {
        {
            saveFileDialog1.InitialDirectory = "C"; // open save file window
            saveFileDialog1.Title = "Save as CSV File"; // promt save as csv
            saveFileDialog1.FileName = DateTime.Now.ToString("dd.MM.yy_HH.mm");
            saveFileDialog1.Filter = "CSV File | *.csv"; // csv format

            if (saveFileDialog1.ShowDialog() != DialogResult.Cancel) // if save dialog opens 
            {
                string value = "";
                DataGridViewRow dr = new DataGridViewRow();
                StreamWriter swOut = new StreamWriter(saveFileDialog1.FileName, true, Encoding.ASCII);

                //write header rows to csv
                for (int i = 0; i <= IncomingDataTable.Columns.Count - 1; i++)
                {
                    if (i > 0)
                    {
                        swOut.Write(",");
                    }
                    swOut.Write(IncomingDataTable.Columns[i].HeaderText);
                }

                swOut.WriteLine();

                //write DataGridView rows to csv
                for (int j = 0; j <= IncomingDataTable.Rows.Count - 1; j++)
                {
                    if (j > 0)
                    {
                        swOut.WriteLine();
                    }
                    dr = IncomingDataTable.Rows[j];

                    for (int i = 0; i <= IncomingDataTable.Columns.Count - 1; i++)
                    {
                        if (i > 0)
                        {
                            swOut.Write(",");

                       }

                        value = dr.Cells[i].Value.ToString();
                        swOut.Write(value);

                    }
                }
                swOut.Close();
            }

    MessageBox.Show("Your data has been successfully saved.", "Message", MessageBoxButtons.OK, MessageBoxIcon.Information); // alert user file has saved



            serialPort1.Close(); // close serial port
            Setup_Page f1 = new Setup_Page(); // open setup page
            this.Hide();
            f1.ShowDialog();
            Close(); // close this page
        }
    }

1 个答案:

答案 0 :(得分:0)

如果输入数据包含换行符并输出它们,则某些应用程序会将它们视为换行符,但有些应用程序不会。记事本没有,所以它看起来像记事本的单行。 Excel识别换行符并开始新行。在写字板而不是记事本中打开CSV文件;写字板会识别换行,而它们在记事本中是不可见的。

简单的解决方法是在编写输入数据之前调用String.Trim。然而,正如Magnus所说,图书馆是你的朋友。如果您使用了一个好的,这可能不是一个问题,因为一个编写良好的库将处理数据中的嵌入换行。

您可以说可以修剪换行符。那么,如果换行符位于数据中间怎么办? Trim不会处理这个问题。不会有任何换行?逗号怎么样?不会有任何逗号,因为数据只是数字?如果它是小数,并且生成它的计算机是在法国,还是许多其他使用逗号作为小数分隔符的国家?数据中的引用怎么样?图书馆可能已经处理了所有这些案件。 (对于使用输出的人来说,逗号小数分隔符可能仍然是一个问题,但至少CSV格式正确。)

但请注意,CSV不是一个明确定义的标准。不同的应用程序和库使用不同的策略来处理上述情况,因此如果您的库没有使用与Excel相同的格式,它仍然可能无法正确加载。