【问题标题】:DataGridView has no columnsDataGridView 没有列
【发布时间】:2013-06-07 13:31:55
【问题描述】:

这是 c# windows 窗体。

我有一个数据网格视图,它应该显示两列、文件名和修改日期。我这样做的方式是通过一项任务。我还有一个只包含文件和路径名、绑定源和数据网格视图的类。此任务运行传递类的方法。任务完成后,该类应该有一个网格视图,然后我可以在表单上将其设置为网格视图。

类如下所示:

class GetLogFilesParameters
{
    public string FileNameandPath;
    public BindingSource BindingSource;
    public DataGridView GridView;

    public GetLogFilesParameters(string _fileNameAndPath)
    {
        FileNameandPath = _fileNameAndPath;
        BindingSource = new BindingSource();
        GridView = new DataGridView();
        GridView.DataSource = BindingSource;
    }
}

我的任务调用的方法如下所示:

private static void GetLogFilesTest(GetLogFilesParameters FormFields)
    {
        Cursor.Current = Cursors.WaitCursor;

        try
        {
            //Setup data table
            DataTable FileList = new DataTable();
            FileList.Clear();
            DataColumn FileNameColumn = new DataColumn();
            FileNameColumn.ColumnName = "FileName";
            FileNameColumn.DataType = System.Type.GetType("System.String");

            DataColumn DateColumn = new DataColumn();
            DateColumn.ColumnName = "ModifiedDate";
            DateColumn.DataType = System.Type.GetType("System.DateTime");

            FileList.Columns.Add(FileNameColumn);
            FileList.Columns.Add(DateColumn);

            //Get a list of files in a directory
            string[] files = Directory.GetFiles(FormFields.FileNameandPath, "*.log");

            //Loop through the files and fill the data table with a row for each
            foreach (string file in files)
            {
                FileInfo FileInformation = new FileInfo(file);
                DataRow row = FileList.NewRow();
                row["FileName"] = FileInformation.Name;
                row["ModifiedDate"] = FileInformation.LastWriteTime;
                FileList.Rows.Add(row);
            }

            //FormFields.GridView.Columns.Add("FileName", "File Name");
            //FormFields.GridView.Columns.Add("ModifiedDate", "Modified Date");
            FormFields.GridView.AutoGenerateColumns = true;

            //Setup the binding source
            FormFields.BindingSource.DataSource = FileList;
            FormFields.BindingSource.Sort = "ModifiedDate DESC";

            FormFields.GridView.Columns[0].Width = (FormFields.GridView.Width / 10) * 6;
            FormFields.GridView.Columns[1].Width = (FormFields.GridView.Width / 10) * 4;
        }
        catch (Exception ex)
        {
            string ErrorText = "Error trying to get the list of log files." + Environment.NewLine + Environment.NewLine;
            ExceptionLogger.LogIt(ErrorText, "Exception");
            MessageBox.Show(ErrorText + ex.ToString());
        }
        finally
        {
            Cursor.Current = Cursors.Default;
        }
    }

我的任务如下所示:

GetLogFilesParameters GetLogFilesParameters = new GetLogFilesParameters(EpicorSenderPath);
            Task tGetFiles1 = new Task(() => GetLogFilesTest(GetLogFilesParameters));
            tGetFiles1.Start();
            tGetFiles1.ContinueWith((antecedent) =>
                {
                    gvEpicorSenderFiles = GetLogFilesParameters.GridView;
                }, TaskScheduler.FromCurrentSynchronizationContext());

我得到的错误是 System.ArgumentOutOfRangeException: Index was out of range。必须是非负数且小于集合的大小。它发生在这一行的方法中:

FormFields.GridView.Columns[0].Width = (FormFields.GridView.Width / 10) * 6;

发生这种情况是因为根据调试,gridview 没有任何列。此外,当它确实有行和数据时。不知道怎么回事。

【问题讨论】:

  • 我不清楚。你在使用异步方法吗?
  • 很抱歉我对您的问题一无所知。我第一次使用任务并打算通过传递先前实例化的类来调用方法。那部分似乎正在工作。我想把它包括在内,因为我希望每个人都能完全理解发生了什么。
  • 无知可能来自我的身边...您可以尝试在 DataGridView.DataBindingComplete 事件中移动这些代码行吗? FormFields.GridView.Columns[0].Width = (FormFields.GridView.Width / 10) * 6; FormFields.GridView.Columns[1].Width = (FormFields.GridView.Width / 10) * 4; [1]:msdn.microsoft.com/en-us/library/…
  • 那行得通。有趣的是,在您分配数据源后,datagridview 的设置不足以让您能够操作应该自动生成的列。但是,我也相信在那个地方有这种类型的代码是更好的组织。
  • 你能把它作为答案让我投票吗?

标签: c# datagridview


【解决方案1】:

我猜(我不明白为什么)您尝试访问尚不存在的列。

尝试在DataGridView.DataBindingComplete事件中移动这些代码行

FormFields.GridView.Columns[0].Width = (FormFields.GridView.Width / 10) * 6; 
FormFields.GridView.Columns[1].Width = (FormFields.GridView.Width / 10) * 4;

【讨论】:

  • 我曾假设在分配数据源后它们会存在。我还没有完全理解 datagridviews。你的建议效果很好。谢谢!
  • 我需要多一点声望才能投票。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2012-06-16
  • 1970-01-01
  • 1970-01-01
  • 2013-12-01
  • 1970-01-01
  • 2017-11-19
相关资源
最近更新 更多