如何检查行是否包含" 0"或者在进行计算之前在DataGridView中为空,并删除此行

时间:2015-09-17 19:24:46

标签: c# winforms datagridview row

家伙! 我的代码需要一些帮助。

所以,故事是,我有一个任务要做一个表单应用程序,用户可以计算离散随机变量的熵。他输入事件和概率,程序计算熵。

所以我使用了DataGridView,一个按钮和一个TextBox。我做了一切,包括限制,例如"所有概率的总和必须等于1"。

但我不能做的是 - 程序本身必须删除或忽略包含" 0"或者是空的行(因为熵的公式包含数字的对数,0的对数是无穷大,这就是程序输出的原因" NaN - 不是数字")。 主要代码位于"按钮"。

以下是它的片段:



for (int z = dataGridView1.Rows.Count - 1; z >= 0; z--)
                    {
                        if (dataGridView1[1, z].Value == null)
                        {
                            dataGridView1.Rows.Remove(dataGridView1.Rows[z]);
                        }
                        else if (dataGridView1[1, z].Value == "0")
                        { dataGridView1.Rows.Remove(dataGridView1.Rows[z]);}
                    }




我在这段代码之后得到的唯一一件事就是错误地说,它无法删除新的"传输的" (不知道如何将其翻译成英文)line。

这是整个代码,位于"按钮":



int counter = 1;
            for (int i = 0; i < dataGridView1.RowCount - 1; i++)
            {
                dataGridView1[0, i].Value = counter++;
            }
            double X = 0;
            double A = 1;
            for (int i = 0; i < dataGridView1.RowCount; i++)
            {
                X += Convert.ToDouble(dataGridView1[1, i].Value);
            }

            if (X < A && X > A)
            {
                MessageBox.Show("Cумма вероятностей меньше или больше 1, введите другие значения вероятностей", "АШИППКА", MessageBoxButtons.OK, MessageBoxIcon.Error);
            }
            else
            {
                double H = 0;
                for (int i = 0; i < dataGridView1.RowCount - 1; i++)
                {
                    for (int z = dataGridView1.Rows.Count - 1; z >= 0; z--)
                    {
                        if (dataGridView1[1, z].Value == null)
                        {
                            dataGridView1.Rows.Remove(dataGridView1.Rows[z]);
                        }
                        else if (dataGridView1[1, z].Value == "0")
                        { dataGridView1.Rows.Remove(dataGridView1.Rows[z]);}
                    }
                    double p = Convert.ToDouble(dataGridView1[1, i].Value);
                    H += p * Math.Log(p, 2.0);
                }
                textBox1.Text = Convert.ToString(-H);
            }
&#13;
&#13;
&#13;

抱歉我的英语不好,不是我的母语,这就是为什么会有很多错误。如果你不明白,请问,请问。

请帮帮我。

1 个答案:

答案 0 :(得分:0)

阐述上述评论。

如果您的DataGridView使用DataTableBindingSource,例如

DataTable table = new DataTable();
table.Columns.Add(...);

DataGridView dgv = new DataGridView();
dgv.DataSource = table;

您的循环引用dataGridView1的任何地方,而是将其替换为table

E.g。

for (int i = 0; i < table.Rows.Count; i++) {
  //...
}