当前位置:  开发笔记 > 编程语言 > 正文

如何对DataGridView列进行排序?

如何解决《如何对DataGridView列进行排序?》经验,为你挑选了1个好方法。

我创建了一个DataTable,如下所示:

        accTable = new DataTable();
        accTable.Columns.Add(new DataColumn("Date"));
        accTable.Columns.Add(new DataColumn("Amt"));
        accTable.Columns.Add(new DataColumn("Item"));

并填写:

            foreach (DataRow myDataRow in myDataSet.Tables[0].Rows)
            {
                DataRow accRow = accTable.NewRow();
                //code skipped

                accRow["Date"] = date.ToString("d"); //tried without converting to string also
                accRow["Amt"] = int.Parse(cells[1].ToString());
                accRow["Item"] = cells[2].ToString();

                accTable.Rows.Add(accRow);
            }

然后我将DataGridView绑定到DataTable accTable,如下所示:

            dataGridView1.DataSource = accTable;

如何使Date列可排序.默认情况下,它按字母顺序排序.我在哪里可以将列的类型设置为DateTime.



1> ChrisF..:

该专栏有一个DataType.你试过这个DateTime吗?

var accTable = new DataTable();

var columnSpec = new DataColumn("Date");
columnSpec.DataType = typeof(DateTime);
accTable.Columns.Add(columnSpec);

当然你可以在一行上做到这一点(感谢BFree):

accTable.Columns.Add("Date",typeof(DateTime));

您将此绑定DataTable到a DataGridView,然后为视图上的每个列设置SortMode属性:

column.SortMode = DataGridViewColumnSortMode.Automatic;

我确实有一些代码完成了所有这些,但我将其转换为使用可空类型(包括DateTime字段),并且它不再像我预期的那样工作.如果我能让它再次正常工作,我会更新这个答案.

推荐阅读
地之南_816
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有