1

我正在循环通过从包含 X 记录的 excel 文件读取的 c# 中的数据集。出于测试目的,我使用 Thread.Sleep() 在读取每条记录后暂停输出一秒钟。我的理解是他们以我编写循环的方式,它应该暂停 1 秒,然后显示 1 行输出(1 条记录),暂停 1 秒,显示 1 行,等等......但是,当我执行我得到的代码时一个 X 秒的长时间停顿,然后所有记录立即输出到屏幕上。有谁知道为什么会这样?我插入了一个断点并单步执行,一切似乎都运行良好(没有错误或任何东西)。抱歉,如果这是一个基本问题,但我是一个绿色程序员。

private void ReadExcelFile()
    {
        string fileAndPath = fileTextBox.Text;
        string fileName = Path.GetFileName(fileAndPath);
        string directoryPath = Path.GetDirectoryName(fileAndPath);

        var connectionString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + fileAndPath + ";Extended Properties=\"Excel 12.0;IMEX=1;HDR=NO;TypeGuessRows=0;ImportMixedTypes=Text\""; ;
        using (var conn = new OleDbConnection(connectionString))
        {
            conn.Open();

            var sheets = conn.GetOleDbSchemaTable(System.Data.OleDb.OleDbSchemaGuid.Tables, new object[] { null, null, null, "TABLE" });
            using (var cmd = conn.CreateCommand())
            {
                cmd.CommandText = "SELECT * FROM [" + sheets.Rows[0]["TABLE_NAME"].ToString() + "] ";

                var adapter = new OleDbDataAdapter(cmd);
                var ds = new DataSet();
                adapter.Fill(ds);

                foreach (DataRow row in ds.Tables[0].Rows)
                {
                    user = row.ItemArray[0].ToString();
                    email = row.ItemArray[1].ToString();
                    password = row.ItemArray[2].ToString();
                    Thread.Sleep(1000);                   

                    excelTextBox.Text += user + "     " + email + "     " + password + "     " + Environment.NewLine;
                }                    
            }
        }
    } 
4

1 回答 1

3

由于您在主线程(UI 线程)上运行此方法,因此该线程不可用于处理事件(例如显示更新)。

您可以执行与此类似的操作来处理 UI 消息: https ://stackoverflow.com/a/3121934/38368

或者,更好的是,重新设计您的代码。例如,使用单独的线程。例如https://stackoverflow.com/a/1216799/38368

于 2013-01-21T17:23:39.503 回答