从C#中的DataGridView获取所选行的第一个单元格

时间:2017-03-11 10:59:55

标签: c# datagridview

我有一个连接到mssql数据库的datagridview,当我按 exec_cmd_btn 时,我希望从所选行中获取第一个单元格 到目前为止,我已经尝试过:

private void exec_cmd_btn_Click(object sender, EventArgs e)
{
    string cell = dataGridView1.SelectedRows[0].Cells[0].Value.ToString();
}

这给我带来了以下错误:

  

指数超出范围。必须是非负数且小于集合的大小。\ r \ nParameter name:index

当我按下数据网格视图时,是否需要创建事件?

1 个答案:

答案 0 :(得分:1)

我猜您可能遇到了SelectedRows属性的问题,因为这取决于DataGridView SelectionMode的设置方式。如果DataGridViews SelectionMode未设置为FullRowSelect,则此实施将无效。既然你试图从第一列获取单元格,那么我不认为这会是一个问题,因为你想确保第一列也被选中。另一个问题是如果DataGridView MultiSelect属性设置为true,那么使用SelectedRows[0]的代码将返回最后选择的行,而不是第一行。如果您想要第一个选定的行,那么您可以使用下面的代码。它将显示所选的第一行和最后一行。希望这会有所帮助。

// The DataGridView SelectionMode must be set  'FullRowSelect' for this to work! 
private void button1_Click(object sender, EventArgs e) {
  if (dataGridView1.SelectedRows.Count > 0) {
    int firstRowIndex = dataGridView1.SelectedRows.Count - 1;
    string cell = dataGridView1.SelectedRows[0].Cells[0].Value.ToString();
    string cell2 = dataGridView1.SelectedRows[firstRowIndex].Cells[0].Value.ToString();
    MessageBox.Show("Last selected row at cell[0] value: " + cell + " First Selected row at cell[0] value: " + cell2);
  }
}