gpt4 book ai didi

c# - 如何对 DataGridView 列进行排序?

转载 作者:太空宇宙 更新时间:2023-11-03 22:27:22 24 4
gpt4 key购买 nike

我创建了一个 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 绑定(bind)到 DataTable accTable,如下所示:

            dataGridView1.DataSource = accTable;

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

最佳答案

该列有一个 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 绑定(bind)到 DataGridView,然后为 View 上的每一列设置 SortMode 属性:

column.SortMode = DataGridViewColumnSortMode.Automatic;

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

关于c# - 如何对 DataGridView 列进行排序?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/857115/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com