我有一个连接到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
当我按下数据网格视图时,是否需要创建事件?
答案 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);
}
}