我已经尝试了一段时间,在数据记录后将数据表导出到visual studio中的csv。
出于某种原因,我在导入excel时会得到奇怪的结果,而记事本很好。似乎在数据中的随机点添加了换行符。
我已经争取了一段时间,所以任何帮助都表示赞赏!
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
}
}
答案 0 :(得分:0)
如果输入数据包含换行符并输出它们,则某些应用程序会将它们视为换行符,但有些应用程序不会。记事本没有,所以它看起来像记事本的单行。 Excel识别换行符并开始新行。在写字板而不是记事本中打开CSV文件;写字板会识别换行,而它们在记事本中是不可见的。
简单的解决方法是在编写输入数据之前调用String.Trim
。然而,正如Magnus所说,图书馆是你的朋友。如果您使用了一个好的,这可能不是一个问题,因为一个编写良好的库将处理数据中的嵌入换行。
您可以说可以修剪换行符。那么,如果换行符位于数据中间怎么办? Trim
不会处理这个问题。不会有任何换行?逗号怎么样?不会有任何逗号,因为数据只是数字?如果它是小数,并且生成它的计算机是在法国,还是许多其他使用逗号作为小数分隔符的国家?数据中的引用怎么样?图书馆可能已经处理了所有这些案件。 (对于使用输出的人来说,逗号小数分隔符可能仍然是一个问题,但至少CSV格式正确。)
但请注意,CSV不是一个明确定义的标准。不同的应用程序和库使用不同的策略来处理上述情况,因此如果您的库没有使用与Excel相同的格式,它仍然可能无法正确加载。