求助:dataGridView用Rows[1].Cells[1]

q45446608 2017-11-18 10:52:41
        private void comboBox_y1_SelectedIndexChanged(object sender, EventArgs e)
{
string sql = "SELECT * FROM region_x WHERE 县市区='" + comboBox_y1.Text + "'";
SqlHelp sqlHelper = new SqlHelp();
DataTable dt = sqlHelper.GetDataTableValue(sql);
dataGridView2.DataSource = dt;
//string cell =dataGridView2.Rows[0].Cells[0].Value.ToString();
}


最后一句注视掉的出问题的,我从数据库中提取出来到datagridview2可以正常显示没问题,但是做提取内容的时候直接报错
...全文
505 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
FainSheeg 2017-11-20
  • 打赏
  • 举报
回复
什么时候出错的,你手动改变Combox的选择项的时候,还是窗体载入的时候?
ManBOyyy 2017-11-20
  • 打赏
  • 举报
回复
gridView1.DataSource = dt; gridView1.DataBind(); 你有那么多dt,最好 gridView1.DataSource = dt.table[1];来判断
大然然 2017-11-20
  • 打赏
  • 举报
回复
private void comboBox_y1_SelectedIndexChanged(object sender, EventArgs e) { if(combox.selectindex >= 0 && !string.isnullorempty(combox.tex)) { string sql = "SELECT * FROM region_x WHERE 县市区='" + comboBox_y1.Text + "'"; SqlHelp sqlHelper = new SqlHelp(); DataTable dt = sqlHelper.GetDataTableValue(sql); dataGridView2.DataSource = dt; if(dt != null && dt.rows.count > 0) { string cell =dataGridView2.Rows[0].Cells[0].Value.ToString(); } } }
大然然 2017-11-20
  • 打赏
  • 举报
回复
以下是我的猜测 你初始化数据的时候, 赋combox的 selectindex = -1, 改属性一被赋值就会马上调用 selectindexchanged事件 但由于是 -1,就是没有选择下来框,导致combox.,text为空 你用一个空的值去查数据库,就为得到一个空的table 然后你有调用table.,rows[0], 结果就导致了下标出错了。
weixin_38346011 2017-11-19
  • 打赏
  • 举报
回复
你没绑定 bind()
秋的红果实 2017-11-18
  • 打赏
  • 举报
回复
Rows[0].Cells[0]有问题,你换成Rows[0].Cells[1],或Rows[1].Cells[1]试一试吧,我记得Grid可以设置header和col样式,具体记不清了
巴士上的邂逅 2017-11-18
  • 打赏
  • 举报
回复
通过DataTable获取值
q45446608 2017-11-18
  • 打赏
  • 举报
回复
我想通过县市区的名字取出ID
qq_37753824 2017-11-18
  • 打赏
  • 举报
回复
索引超出范围说明你压根没这行,或者有着行没这个单元格。
dbfC#DataGridView中的常用技巧 只列出技巧部分,后面会有补充 0(最基本的技巧). 获取某列中的某行(某单元格)中的内容 this.currentposition = this.dataGridView1.BindingContext [this.dataGridView1.DataSource, this.dataGridView1.DataMember].Position; bookContent = this.database.dataSet.Tables[0].Rows [this.currentposition][21].ToString().Trim(); MessageBox.Show(bookContent); 1、自定义列 //定义列宽 this.dataGridView1.Columns[0].Width = 80; this.dataGridView1.Columns[1].Width = 80; this.dataGridView1.Columns[2].Width = 180; this.dataGridView1.Columns[3].Width = 120; this.dataGridView1.Columns[4].Width = 120; Customize Cells and Columns in the Windows Forms DataGridView Control by Extending Their Behavior and Appearance Host Controls in Windows Forms DataGridView Cells 继承 DataGridViewTextBoxCell 类生成新的Cell类,然后再继承 DataGridViewColumn 生成新的Column类,并指定 CellTemplate为新的Cell类。新生成的Column便可以增加到DataGridView中去。 2、自动适应列宽 Programmatically Resize Cells to Fit Content in the Windows Forms DataGridView Control Samples: DataGridView.AutoSizeColumns( DataGridViewAutoSizeColumnCriteria.HeaderAndDisplayedRows); DataGridView.AutoSizeColumn( DataGridViewAutoSizeColumnCriteria.HeaderOnly, 2, false); DataGridView.AutoSizeRow( DataGridViewAutoSizeRowCriteria.Columns, 2, false); DataGridView.AutoSizeRows( DataGridViewAutoSizeRowCriteria.HeaderAndColumns, 0, dataGridView1.Rows.Count, false); 3、可以绑定并显示对象 Bind Objects to Windows Forms DataGridView Controls 4、可以改变表格线条风格 Change the Border and Gridline Styles in the Windows Forms DataGridView Control Samples: this.dataGridView1.GridColor = Color.BlueViolet; this.dataGridView1.BorderStyle = BorderStyle.Fixed3D; this.dataGridView1.CellBorderStyle = DataGridViewCellBorderStyle.None; this.dataGridView1.RowHeadersBorderStyle = DataGridVie

110,561

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Web++
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧