关于C#中 对于datagridview 单击任意一个单元格,获取那一行数据的语句

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了关于C#中 对于datagridview 单击任意一个单元格,获取那一行数据的语句相关的知识,希望对你有一定的参考价值。

string strBookName = dataGridView1.Rows[0].Cells[1].Value.ToString(); 为什么这样写了后无论点击哪行的单元格都是第一行的数据呢? 该怎么改呢?谢谢各位了~

这句代码是写在dataGridView1控件的CellClick事件中的吗?如果是的话,代码如下:
private void dataGridView1_CellClick(object sender, DataGridViewCellEventArgs e)

//被点击的单元格的行索引号在事件的参数e中,e.RowIndex是行索引,e.ColumnIndex是列索引
string strBookName=dataGridView1.Rows[e.RowIndex].Cells[1].Value.ToString());
//.......其它代码
追问

恩,谢谢,我刚用过了,但是第二行语句就有问题了
DataRow dr = dbc.Query(string.Format("select * from book where bookname='0'", strBookName)).Tables[0].Rows[0];
Tables[0].Rows[0]就报错了 是怎么回事呢?

追答

dbc.Query(...)是个什么东东?报错,报什么样的错呢?

追问

是我写的数据库访问层 ,在窗体里来调用数据库查询方法Query 报错就是在第二行语句 ”在位置 0 处没有任何行。“

追答

哦。那就是你的这句SQL查询并没有数据返回,返回的表为空,你要访问它的第一行当然会出错。建议在对返回数据进行操作时,先判断一下它是否为空。

追问

是怎么回事呢? 因为我的表里有数据啊 如果用我提问的那一段代码 就能显示出来

追答

请在出错处设断点调试一下。

参考技术A private void dataGridView1_CellClick(object sender, DataGridViewCellEventArgs e)

if (string strBookName=dataGridView1.Rows[e.RowIndex].Cells[1].Value!=null)

string strBookName=dataGridView1.Rows[e.RowIndex].Cells[1].Value.ToString());


参考技术B Rows[0]当然是第一行 SelectedRow 获取对 GridViewRow 对象的引用,该对象表示控件中的选中行。
SelectedValue 获取 GridView 控件中选中行的数据键值。
具体可以去msdn的api看追问

谢谢~ 我用了selectedrows 可运行的时候报错了,
string strBookName = dataGridView1.SelectedRows[0].Cells[1].Value.ToString();
索引超出范围。必须为非负值并小于集合大小。 怎么解决呢?

追答

首先你得在前台启用 启用选定内容 然后在服务端事件那里选择SelectedIndexChanging事件,双击会在后台出现代码,然后在里面获取,不然程序不知道你选的是哪行,获取就这么写
string s = GridView1.SelectedRow.Cells[1].Text; cells里是第几个单元格

追问

没找到SelectedIndexChanging
T_T 只有SelectionChanged

追答

SelectionChanged就可以,这两个只是选择前后和执行,不知道你具体什么功能,单纯要单元格数据的话取出后放到全局变量就可以

C#中dataGridView单击事件怎么写?

this.dgvPcase.CellClick += new System.EventHandler(this.dgvPcase_CellClick);
上面这句提示:无法将类型"System.EventHandler"隐式转换为"System.Windows.Forms.DataGridViewCellEventHandler"
————————————————————我是分割线——————————————————
private void dgvPcase_CellClick(object sender, EventArgs e)

this.dgvPcase.CellClick+=System.Windows.Forms.DataGridViewCellEventHandler(this.dgvPcase_CelClick)追问

无法定义
System.Windows.Forms.DataGridViewCellEventHandler上下文无效

追答

添加了System.Windows.Forms的引用没?

或者直接在DataGridView的属性栏中,选择事件,双击生成事件方法

参考技术A CellClick(object sender, DataGridViewCellEventArgs e)
你dgvPcase_CellClick的事件错了
参考技术B MouseDown 这个事件
在里面写下面的代码
if(e.butten==Mouse.Right)

// 你想干什么?全加在这里

以上是关于关于C#中 对于datagridview 单击任意一个单元格,获取那一行数据的语句的主要内容,如果未能解决你的问题,请参考以下文章

C#中dataGridView单击事件怎么写?

如何在 Windows 窗体 C# 中单击按钮通过 DataGridView 更新数据库中的布尔字段

C#中dataGridView怎么实现右键单击时获取点击位置所在的行数RowIndex?

急!在datagridview中修改或增加数据,单击按钮能将写入的数据保存到数据库里?求C#源代码,谢谢交个朋友

c# winform DataGridView单击选中一整行,只能单选,不能选择多行,只能选择一行

C# winform 如何用datagridview增、删、改数据