获取并设置DataGridView的排序(列和升序/降序)

时间:2012-05-29 19:18:38

标签: c# sorting datagridview datagridviewcolumn

我遇到了一个小问题。我需要保存排序(通过列和升序或降序)并在下一次启动程序时加载它。 通过

获取当前选择的列是没有问题的
    private int GetSortColumn()
    {
        DataGridViewColumn sortColumn = this.dataGridView.SortedColumn;
        if (sortColumn != null)
        {
            Properties.Settings.Default.sortingColumnSortMode = dataGridView.SortOrder;
            return sortColumn.Index;
        }
        else
            //error
            return -1;
    }

并将数据保存在我的设置中。 设置此属性也没问题:

    private void SetSortColumn(int indexOfColumn)
    {
        if (indexOfColumn != null && indexOfColumn != -1)
        {
            this.dataGridView.Sort(this.dataGridView.Columns[indexOfColumn], ListSortDirection.Descending);
        }
    }

但我还需要保存并设置升序或降序属性。我该怎么做呢? 有没有办法使用dataGridView.SortedColumn获取ListSortDirection?或者,如果dataGridView按升序或降序排序,是否有更好的解决方案?

谢谢和问候! reijin

2 个答案:

答案 0 :(得分:1)

好吧,我只需在我的SetSortColumn中添加一个开关就可以解决我的问题:

    private void SetSortColumn(int indexOfColumn)
    {
        if (indexOfColumn != null && indexOfColumn != -1)
        {
            ListSortDirection listSort;
            switch (Properties.Settings.Default.sortingColumnSortMode)
            {
                case SortOrder.Ascending:
                    listSort = ListSortDirection.Ascending;
                    break;

                case SortOrder.Descending:
                    listSort = ListSortDirection.Descending;
                    break;

                default:
                    listSort = ListSortDirection.Descending;
                    break;

            }

            this.dataGridView.Sort(this.dataGridView.Columns[indexOfColumn], listSort);
        }
    }

也许它会帮助别人;)

答案 1 :(得分:1)

@Ken,这将起作用

我不知道这是否仍然有用,但这看起来是一种更简单的方法:)

if(gridView1.Columns[e.ColumnIndex].HeaderCell.SortGlyphDirection == System.Windows.Forms.SortOrder.Descending)
{
     // you can ascending if you want
     gridView1.Sort(gridView1.Columns[e.ColumnIndex], ListSortDirection.Ascending);
}
else
{
      // you can descending if you want
     gridView1.Sort(gridView1.Columns[e.ColumnIndex], ListSortDirection.Descending);
}