前提・実現したいこと
csvファイルから文字列として読み込んだ値をdouble型に変更したい.
発生している問題・エラーメッセージ
System.FormatException: '入力文字列の形式が正しくありません。'
該当のソースコード
while (stomach.Peek() >= 0) { string[] col = stomach.ReadLine().Split(','); string k = col[0]; string j = col[1]; if (double.TryParse(col[0], out double x) && double.TryParse(j, out double y)) { chart1.Series[0].Points.AddXY(x, y); } else { error++; double a = double.Parse(k); } }
試したこと
ParseメソッドやTryParseメソッドで変換を試みたが変更することが出来なかった.
補足情報(FW/ツールのバージョンなど)
実際にどのような文字列を変換しようとしたか示せますか?
0.00.00.00.0500,-7.877
0.00.00.00.1000,-7.953
の値をcsvファイルから読み込み配列colに代入をしました.この配列に入っている文字列をdouble型に変換するため,
double a = double.Parse(k);
を行ったところ上記のエラーメッセージをはいてしまいました.
そのようなデータですと、Parseで変換する文字列は"0.00.00.00.0500"と"-7.877"になるかと思います。
"-7.877"のほうは問題ありませんが、"0.00.00.00.0500"のほうは小数を表現する文字列としておかしいと思いませんか?
解決しました!
"0.00.00.00.0500"を少数表現することは出来ないのですね.解決していただきありがとうございます。
"0.00.00.00.0500"を変換してどういう値になることを期待したのでしょうか?
そちらのほうが気になります。
また、解決したのであれば、y_waiwiaさんの回答も同じ内容なので、そちらをBAするなりして解決済みにしてください。
左からd.hh.mm.ss.fffと時間を表しグラフを作るつもりだったので、x軸の時間の値になることを期待していました。
分かりました、解決済みにします。
そうなると、時間情報への変換が必要なので合って、doubleではないのではないですか?
TimeSpan.ParseExact(https://docs.microsoft.com/ja-jp/dotnet/api/system.timespan.parseexact?view=netframework-4.8#System_TimeSpan_ParseExact_System_String_System_String_System_IFormatProvider_System_Globalization_TimeSpanStyles_)を利用することになるかと思います。
この場合時間軸の変換が必要になるのですね.何度も返信ありがとうございます.
回答1件
あなたの回答
tips
プレビュー