自定义在winform中的datagridview中排序

时间:2015-12-16 14:02:01

标签: c# winforms datagridview datatable

我的数据表有

之类的行
ID Name
2  A
4  B
3  C
5  D
1  E
List order = new List() { "1", "3", "2", "5", "4" }

--------------按列表排序-----------------

ID Name
1   E
3   C
2   A
5   D
4   B 

任何人都可以帮助实现这一点..我在Winforms中使用DataTable。

3 个答案:

答案 0 :(得分:4)

已经给出的另一个解决方案是循环您的订单列表,然后对您的源列表进行排序。

// source list
List<Foo> lSource = new List<Foo>() {
    new Foo() { ID = 2, Name = "A" },
    new Foo() { ID = 4, Name = "B" },
    new Foo() { ID = 3, Name = "C" },
    new Foo() { ID = 5, Name = "D" },
    new Foo() { ID = 1, Name = "E" },
};

// order list
List<int> order = new List<int>() { 1, 3, 2, 5, 4 };

// loop order list and sort source list
order.ForEach(x =>
{
    lSource = lSource.OrderBy(g => g.ID == x).ToList();
});

// set datasource
dataGridView1.DataSource = lSource;

我刚添加了一个包含Fooint ID的课程string Name,因为您没有共享整个代码。

答案 1 :(得分:2)

我认为你可以join orderAsEnumerable method以及on部分你可以均衡它们并选择行,然后你可以生成一个来自DataTable 使用CopyToDataTable method进行查询。

var dt = new DataTable();
var dc = new DataColumn() { ColumnName = "ID", DataType = typeof(string) };
dt.Columns.Add(dc);
dc = new DataColumn() { ColumnName = "Name", DataType = typeof(string) };
dt.Columns.Add(dc);
dt.Rows.Add(new object[] { "2", "A" });
dt.Rows.Add(new object[] { "4", "B" });
dt.Rows.Add(new object[] { "3", "C" });
dt.Rows.Add(new object[] { "5", "D" });
dt.Rows.Add(new object[] { "1", "E" });

List<string> order = new List<string>() { "1", "3", "2", "5", "4" };

var query = from item in order
            join row in dt.AsEnumerable() on item equals row.Field<string>("ID")
            select row;

var result = query.CopyToDataTable();

结果将是;

enter image description here

我不确定这是不是最好的方式,但这似乎适合你的情况。

答案 2 :(得分:0)

您可以加入两个列表(带有项目的列表和带有已排序ID的列表),然后选择项目:

using System;
using System.Collections.Generic;
using System.Linq;

public class Program
{
    public static void Main()
    {
        var list = new List<Item>{
            new Item { Id = 2, Text = "A" },
            new Item { Id = 4, Text = "B" },
            new Item { Id = 3, Text = "C" },
            new Item { Id = 5, Text = "D" },
            new Item { Id = 1, Text = "E" }
        };
        var sortorder = new List<int> { 1, 3, 2, 5, 4 };

        var sortedlist = sortorder.Join(list, x => x, y => y.Id, (x,y) => y);

        foreach(var item in sortedlist) 
            Console.WriteLine("{0} {1}", item.Id, item.Text);
    }
}