-2

我有代码,一切都很好,直到我输入大于3000 的数字,结果将是负数,请帮忙。

我不知道为什么会这样,我已经调试过了,或者我用int声明了它?

我提到的总价值是 int total=数量*成本;

顺便说一句,有没有办法阻止用户在数量列中输入除数字之外的任何其他内容?

 private void G2_CellEndEdit(object sender, DataGridViewCellEventArgs e)
    {
        try
        {
            int quantity, cost;
            if (int.TryParse(G2.Rows[e.RowIndex].Cells["Quantity"].Value.ToString(), out quantity) && int.TryParse(G2.Rows[e.RowIndex].Cells["Cost2"].Value.ToString(), out cost))
            {
                int total= quantity * cost;
                G2.Rows[e.RowIndex].Cells["Total"].Value = total.ToString();
            }

            int quan, mini;

            quan = Convert.ToInt32(G2.Rows[e.RowIndex].Cells["Quantity"].Value);
            mini = Convert.ToInt32(G2.Rows[e.RowIndex].Cells["MinimumOrder2"].Value);

            if (quan < mini)
            {
                MessageBox.Show("QUANTITY must be GREATER or EQUAL to MINIMUM ORDER", "STOP", MessageBoxButtons.OK, MessageBoxIcon.Error);
                G2.Rows[e.RowIndex].Cells["Quantity"].Value = "";
                G2.Rows[e.RowIndex].Cells["Total"].Value = "";
                return;

            }
            else
            {
                //Sum the Total Column to TOTAL VALUES text box
                decimal TotalValue = 0;
                for (int i = 0; i < G2.Rows.Count; i++)
                {
                    if (G2.Rows[i].Cells["Total"].Value == DBNull.Value)
                    {
                        return;
                    }
                    else
                    {
                        TotalValue += Convert.ToDecimal(G2.Rows[i].Cells["Total"].Value);
                    }
                }

                totalvalue.Text = TotalValue.ToString();
            }

        }
        catch (Exception ex)
        {
            MessageBox.Show("Please Enter Only Number");
            return;
        }

    }

用户输入示例

4

3 回答 3

1

[已解决] 不要再使用 int 了,将其改为十进制

private void G2_CellEndEdit(object sender, DataGridViewCellEventArgs e)
{
    try
    {
        decimal quantity, cost;
        if (decimal .TryParse(G2.Rows[e.RowIndex].Cells["Quantity"].Value.ToString(), out quantity) && decimal .TryParse(G2.Rows[e.RowIndex].Cells["Cost2"].Value.ToString(), out cost))
        {
            decimal total= quantity * cost;
            G2.Rows[e.RowIndex].Cells["Total"].Value = total.ToString();
        }

        int quan, mini;

        quan = Convert.ToInt32(G2.Rows[e.RowIndex].Cells["Quantity"].Value);
        mini = Convert.ToInt32(G2.Rows[e.RowIndex].Cells["MinimumOrder2"].Value);

        if (quan < mini)
        {
            MessageBox.Show("QUANTITY must be GREATER or EQUAL to MINIMUM ORDER", "STOP", MessageBoxButtons.OK, MessageBoxIcon.Error);
            G2.Rows[e.RowIndex].Cells["Quantity"].Value = "";
            G2.Rows[e.RowIndex].Cells["Total"].Value = "";
            return;

        }
        else
        {
            //Sum the Total Column to TOTAL VALUES text box
            decimal TotalValue = 0;
            for (int i = 0; i < G2.Rows.Count; i++)
            {
                if (G2.Rows[i].Cells["Total"].Value == DBNull.Value)
                {
                    return;
                }
                else
                {
                    TotalValue += Convert.ToDecimal(G2.Rows[i].Cells["Total"].Value);
                }
            }

            totalvalue.Text = TotalValue.ToString();
        }

    }
    catch (Exception ex)
    {
        MessageBox.Show("Please Enter Only Number");
        return;
    }

}
于 2017-03-14T08:11:33.437 回答
0

另一个问题可能是允许用户在 Total 中输入值。下面是仅允许数量字段中的数字的代码

private void G2_EditingControlShowing(object sender, DataGridViewEditingControlShowingEventArgs e)
    {
        String sCellName = G2.Columns[G2.CurrentCell.ColumnIndex].Name.ToUpper();
        if (sCellName == "QUANTITY") //----change with yours
        {

            e.Control.KeyPress +=  new KeyPressEventHandler(Control_KeyPress);


        }
    }

    private void Control_KeyPress(object sender, KeyPressEventArgs e)
    {

        if (!char.IsControl(e.KeyChar) && !char.IsDigit(e.KeyChar) && e.KeyChar != '.')
        {
            e.Handled = true;
        }

        // only allow one decimal point
        if (e.KeyChar == '.'
            && (sender as TextBox).Text.IndexOf('.') > -1)
        {
            e.Handled = true;
        }
    }
于 2017-03-14T07:53:58.417 回答
0

一个问题是“总循环”。我认为return应该是一个continue

if (G2.Rows[i].Cells["Total"].Value == DBNull.Value)
{
    continue;
}

另一个问题是,total为点击的行计算的int不是 a decimial。将代码更改为:

int quantity;
decimal cost;
if(int.TryParse(G2.Rows[e.RowIndex].Cells["Quantity"].Value.ToString(), out quantity) && 
   decimal.TryParse(G2.Rows[e.RowIndex].Cells["Cost2"].Value.ToString(), out cost))
        {
            int total= quantity * cost;
            G2.Rows[e.RowIndex].Cells["Total"].Value = total.ToString();
        }
于 2017-03-14T07:40:51.063 回答