winform的datagridview使用方法

2 篇文章 0 订阅
1 篇文章 0 订阅

添加行

dataGridView1.Rows.Add();

添加行和多个数据

dataGridView1.Rows.Add("false","a,","b");

添加行,数据为一个数组

dataGridView1.Rows.Add(string[] a);

添加泛型数据,注意,泛型是不能够直接添加的。

dataGridView1.Rows.Add(xulie.ToArray());

另外,如下语句看起来没错,单元格的内容有时候是“”或者null,但是依旧会报错未将对象引用设置引用到实例。似乎可以返回空或者null,但是是不行的

Console.WriteLine(dataGridView2.Rows[w].Cells[r].Value.ToString());

可以这样做

            for (int i = 0; i < dataGridView2.RowCount; i++)
                {
                    for (int f = 0; f < dataGridView2.ColumnCount; f++)
                    {
                        if (dataGridView2.Rows[i].Cells[f].Value == null)
                        {
                            dataGridView2.Rows[i].Cells[f].Value = "";
                        }
                    }
                }

单元格的点击事件

private void dataGridView1_CellClick(object sender, DataGridViewCellEventArgs e)

获取点击单元格所在的行

private void dataGridView1_CellClick(object sender, DataGridViewCellEventArgs e)
        {
            DataGridViewRow dgr = dataGridView1.CurrentRow;
        }

获取点击单元格所在的行的行索引

private void dataGridView1_CellClick(object sender, DataGridViewCellEventArgs e)
        {
            DataGridViewRow dgr = dataGridView1.CurrentRow;
            dgr.Index;
        }

获取点击单元格或者本行的内容

private void dataGridView1_CellClick(object sender, DataGridViewCellEventArgs e)
        {
            DataGridViewRow dgr = dataGridView1.CurrentRow;
            dgr.Cells[1].Value;
            dgr.Cells[1].Value.ToString();   //两种都可以
        }


需要注意的是点击页眉行与第一行索引的值都为0,并且页眉行内容不能通过这种方式访问内容,会报错未将对象设置引用到实例。而我们希望防止用户点击页眉报错,可以加如下代码。

if (dgr != null)
            {
             //代码
            }

因为在点击页眉时dgr的值为null。
遇到一个不明所以的BUG,获取datagridview的Checkbox列的值错误,在此记录,待有缘解开。
代码在下,即使Value为true也不行。

if (dataGridView1.Rows[i].Cells[0].Value != null && dataGridView1.Rows[i].Cells[0].Value.ToString() == "true")

替换为

bool.Parse(dataGridView1.Rows[i].Cells[0].Value.ToString())
  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值