集合已修改;可能无法执行枚举操作; 索引超出范围;未将对象引用设置到对象的实例

【1】集合已修改;可能无法执行枚举操作

foreach (var city in list)
            {
                if (city.CITYCODE.Contains("410706"))
                {
                    list.Remove(city);
                }
            }

foreach语句是对枚举数的包装,它只允许从集合中读取,不允许写入集合。

也就是,不能在foreach里遍历的时侯把它的元素进行删除或增加的操作的

[C#]集合已修改;可能无法执行枚举操作

 

【2】其他信息: 索引超出范围。必须为非负值并小于集合大小。

for (var i=0;i<118;i++)
            {
                if (list[i].CITYCODE.Contains("410706"))//,410705,410522
                {
                    list.RemoveAt(i);
                }
            }

            for (var i=0;i< list.Count(); i++)
            {
                if (list[i].CITYCODE.Contains("410706,410705,410522"))//
                {
                    list.RemoveAt(i);
                }
            }

    【3】其他信息: 未将对象引用设置到对象的实例。

            var result = from a in list
                             join c in airQuality on a.CITYCODE equals c.CITYCODE 
                             //orderby a.AQI ascending, a.CITYCODE ascending
                             into joinEmpDept
                             from da in joinEmpDept.DefaultIfEmpty()
                             select new
                             {
                                 da.PM10,
                                 da.PM25,
                                 da.CO,
                                 da.NO2,
                                 da.SO2,
                                 da.O3,
                                 da.AQI,
                                 da.AIRLEVEL,
                                 a.CITY
                             };

没有做null值的判断

                var result = from a in list
                             join c in airQuality on a.CITYCODE equals c.CITYCODE 
                             //orderby a.AQI ascending, a.CITYCODE ascending
                             into joinEmpDept
                             from da in joinEmpDept.DefaultIfEmpty()
                             select new
                             {
                                 PM10=da==null? -999 :da.PM10,
                                 PM25= da == null ? -999 : da.PM25,
                                 CO= da == null ? -999 : da.CO,
                                 NO2= da == null ? -999 : da.NO2,
                                 SO2= da == null ? -999 : da.SO2,
                                 O3= da == null ? -999 : da.O3,
                                 AQI= da == null ? -999 : da.AQI,
                                 AIRLEVEL=da.AIRLEVEL,
                                 a.CITY
                             };

 

没有解决

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我来解答你的问题。首先,这个错误是因为你在循环遍历 DataGridView 的列时,同时又在其中添加了按钮,并且在添加按钮时触发了 DataGridView 的事件,导致了集合修改的错误。解决这个问题的方法有两种: 1. 使用一个额外的 List 来存储所有的按钮,遍历完 DataGridView 的列后再将所有按钮添加到 DataGridView 中。 2. 在添加按钮时先解除 DataGridView 的事件绑定,添加完按钮后再重新绑定事件。 下面是第一种方法的示例代码,其中假设 DataGridView 的名称为 dgv: ``` Dim btnList As New List(Of Button) ' 用来存储所有的按钮 For i As Integer = 0 To dgv.Columns.Count - 1 ' 遍历所有的列 Dim btn As New Button btn.Text = "按钮" & i btn.Tag = i ' 设置按钮的 Tag 属性为列的索引,方便后面处理点击事件时获取对应的列 btnList.Add(btn) ' 将按钮添加到 List 中 Next For i As Integer = 0 To dgv.Rows.Count - 1 ' 遍历所有的行 For j As Integer = 0 To btnList.Count - 1 ' 遍历所有的按钮 dgv.Rows(i).Cells.Add(btnList(j).Clone()) ' 将按钮添加到单元格中 Next Next AddHandler dgv.CellClick, AddressOf dgv_CellClick ' 绑定 DataGridView 的点击事件 ' DataGridView 点击事件处理函数 Private Sub dgv_CellClick(sender As Object, e As DataGridViewCellEventArgs) If e.ColumnIndex >= 0 AndAlso TypeOf dgv.Columns(e.ColumnIndex) Is DataGridViewButtonColumn Then ' 判断是否点击了按钮列 Dim btn As Button = dgv.Rows(e.RowIndex).Cells(e.ColumnIndex).Value ' 获取点击的按钮 Dim colIndex As Integer = CInt(btn.Tag) ' 获取按钮对应的列索引 ' 处理点击事件 MessageBox.Show("点击了第 " & e.RowIndex + 1 & " 行第 " & colIndex + 1 & " 列的按钮") End If End Sub ``` 如果你想要使用第二种方法,可以将添加按钮的代码修改为: ``` Dim btn As New Button btn.Text = "按钮" & i btn.Tag = i AddHandler btn.Click, AddressOf btn_Click ' 绑定按钮的点击事件 dgv.Rows(i).Cells.Add(btn) RemoveHandler dgv.CellClick, AddressOf dgv_CellClick ' 解除 DataGridView 的点击事件绑定 AddHandler dgv.CellClick, AddressOf dgv_CellClick ' 重新绑定 DataGridView 的点击事件 ``` 其中,btn_Click 函数为按钮的点击事件处理函数,具体实现可以根据你的需求来编写。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值