0

このエラーが発生しています:

Error: Format Exception: Input string was not in a correct format.

foreach (DataRow row in dtChanges.Rows)
            {
                using (SQLiteConnection conn = new SQLiteConnection(connString))
                {
                    conn.Open();
                    SQLiteCommand upCmd = new SQLiteCommand(@"update.......",conn);
           upCmd.Parameters.AddWithValue("@Flux",float.Parse(row["Flux"].ToString()));

この行 ["Flux"] は datagridview からのものです。"" 文字列の可能性があります。これが問題の原因だと思います。Flux は DB の数値です。私はsqlite DBです。"" を 10 進数に変換できないというこのエラーは理解しています。しかし、これに取り組む最善の方法は何でしょうか?

Stack Trace: 
       at System.Number.ParseSingle(String value, NumberStyles options, NumberFormatInfo numfmt)
       at System.Single.Parse(String s)
       at RVEST.frmVesselData.SaveData(DataGridView dgv) in C:\D_Drive_Stuff\RVESTV2\RVEST\frmVesselData.cs:line 249
       at RVEST.frmVesselData.btnSave_Click(Object sender, EventArgs e) in C:\D_Drive_Stuff\RVESTV2\RVEST\frmVesselData.cs:line 190
       at System.Windows.Forms.Control.OnClick(EventArgs e)
       at System.Windows.Forms.Button.OnClick(EventArgs e)
       at System.Windows.Forms.Button.OnMouseUp(MouseEventArgs mevent)
       at System.Windows.Forms.Control.WmMouseUp(Message& m, MouseButtons button, Int32 clicks)
       at System.Windows.Forms.Control.WndProc(Message& m)
       at System.Windows.Forms.ButtonBase.WndProc(Message& m)
       at System.Windows.Forms.Button.WndProc(Message& m)
       at System.Windows.Forms.Control.ControlNativeWindow.OnMessage(Message& m)
       at System.Windows.Forms.Control.ControlNativeWindow.WndProc(Message& m)
       at System.Windows.Forms.NativeWindow.DebuggableCallback(IntPtr hWnd, Int32 msg, IntPtr wparam, IntPtr lparam)
       at System.Windows.Forms.UnsafeNativeMethods.DispatchMessageW(MSG& msg)
       at System.Windows.Forms.Application.ComponentManager.System.Windows.Forms.UnsafeNativeMethods.IMsoComponentManager.FPushMessageLoop(IntPtr dwComponentID, Int32 reason, Int32 pvLoopData)
       at System.Windows.Forms.Application.ThreadContext.RunMessageLoopInner(Int32 reason, ApplicationContext context)
       at System.Windows.Forms.Application.ThreadContext.RunMessageLoop(Int32 reason, ApplicationContext context)
       at System.Windows.Forms.Application.Run(Form mainForm)
       at RVEST.Program.Main() in C:\RVEST\Program.cs:line 26
       at System.AppDomain._nExecuteAssembly(RuntimeAssembly assembly, String[] args)
       at System.AppDomain.ExecuteAssembly(String assemblyFile, Evidence assemblySecurity, String[] args)
       at Microsoft.VisualStudio.HostingProcess.HostProc.RunUsersAssembly()
       at System.Threading.ThreadHelper.ThreadStart_Context(Object state)
       at System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state, Boolean ignoreSyncCtx)
       at System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state)
       at System.Threading.ThreadHelper.ThreadStart()

ありがとうございます

4

1 に答える 1

0

ゼロでよければ、

float result;
result = row["flux"] != null && float.TryParse(row["flux"].ToString(), out result) ? result :0;

upCmd.Parameters.AddWithValue("@Flux", result);

Null および空の値は 0 に変換されます。

null値を取得したい場合:

float result;
    var res= row["flux"] != null && float.TryParse(row["flux"].ToString(), out result) ? (float?)result :null;

upCmd.Parameters.AddWithValue("@Flux", res);

いかなる場合でも、

確認する必要があります: - "ToString()" を呼び出す前に、row["flux"] が null であるかどうか。- 次に、value.ToString() を解析して float にできるかどうかを確認します。

于 2012-05-12T21:23:17.573 に答える