1

我正在尝试使用 for 循环访问和更改数据表中下一行的值,但出现错误:

System.IndexOutOfRangeException: There is no row at position 247.

我知道在最后一个循环中,它不会找到下一行。但是我检查它是否存在,然后只修改值,但它不起作用。
这是我的代码:

for (int i = 0; i < dt.Rows.Count; i++)
{
  DataRow _row = dt.Rows[i];
  if (_row[1].ToString() != "" && _row[0].ToString() != "")
  {
    int temp = i + 1;
    if (dt.Rows[temp].GetType() == typeof(DataRow))
    {
        dt.Rows[temp][0] = _row[0].ToString();
     }
   }
 }

任何帮助,将不胜感激。谢谢。

4

1 回答 1

4

这失败了,因为没有要获取的行,所以它甚至在调用之前就失败了GetType

if (dt.Rows[temp].GetType() == typeof(DataRow))
//  ^^^^^^^^^^^^^  <-- throws an IndexOutOfRangeException here

相反,您可以迭代到比行数少一:

for (int i = 0; i < dt.Rows.Count - 1; i++)
{
    DataRow row = dt.Rows[i];
    DataRow nextRow = dt.Rows[i + 1];
    // ...
}

如果你想对最后一行做一些特别的事情,你可以在循环之后做。

于 2012-07-04T23:22:41.350 回答