データロギング後にVisual Studioのcsvにデータテーブルをエクスポートしようとしています。ビジュアルスタジオからcsvにエクスポートするときにストリームライターをランダムに追加するC#
何らかの理由で、私は驚くべき結果を得ていますが、メモ帳は問題ありません。改行はデータ内のランダムなポイントに追加されているようです。
私はしばらくの間これを戦っているので、どんな助けもありがとう!
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
}
}
あなたのためにこれを行うライブラリがあります:https://www.nuget.org/packages/CsvHelper/ – Magnus
@Magnus私の問題はCSVとしてエクスポートされていません。エクスポート中にデータ内に改行があります。 – charley
受信データに改行が含まれていますか?メモ帳の代わりにワードパッドでCSVファイルを開いてみてください。ワードパッドは改行で折れてしまいますが、メモ帳は破損しません。それが問題なら、すべての着信データを書き留めてから書き込んでください。 – Lithis