闪开我要上天了 2021-10-21 14:21 采纳率: 66.7%
浏览 26
已结题

双重for循环中嵌套foreach操作DataGrid速度慢

DataGrid加载数据时很慢,要6秒左右才显示。。。
是因为设置了单元格颜色才变慢的吗?


 int row = excelDataGridViewX.Rows.Count;//得到总行数
            int cell = excelDataGridViewX.Rows[0].Cells.Count;//得到总列数
            for (int i = 0; i < row; i++)//得到总行数并在之内循环
            {
                for (int j = 0; j < cell; j++)//得到总列数并在之内循环
                {
                    foreach (string str in System.IO.File.ReadAllLines("Fail_Number.txt"))
                    {
                        if ((str != null && str != "") && str == excelDataGridViewX.Rows[i].Cells[j].Value.ToString())
                        {
                            this.excelDataGridViewX[j, i].Style.BackColor = Color.Red;
                            break;
                        }
                    }

  • 写回答

3条回答 默认 最新

  • 於黾 2021-10-21 14:42
    关注

    foreach不要放到双重for循环里面去,这不变成3重for循环了吗
    你调用ReadAllLines是在反复读文件,那能不慢才怪

    你先把读到的内容放进List<string> LL,然后判断LL.contains(str)
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 10月21日
  • 已采纳回答 10月21日
  • 修改了问题 10月21日
  • 创建了问题 10月21日