从左到右对列表数据进行多行排序

时间:2019-02-23 12:50:28

标签: c# linq sorting arraylist aforge

我正在研究aforge。我在Blob旁边的屏幕上绘制了一个数据列表。我还将数据添加到列表框中。但是,它不是按照从左到右的顺序添加,而是按照斑点的XY坐标添加,如下所示在第一个列表框中。

enter image description here

我尝试通过OrderBy方法使用Linq对列表进行排序,但随后它以升序对整个列表进行排序。我不希望那样,我希望列表按第一行,第二行等排序。我尝试使用take <>按第一行对其进行排序,但它仅对5 int的第一行进行排序,然后停止。

代码:

        int n = 5;
        elements = elements.Take(n).OrderBy(i => i).ToList();
        foreach (var cogxx in elements)
        {
           listBox2.Items.Add(cogxx);                
        }

如果列表坐标=新列表{80,90,100,60,70,20,40,30,10,50,},如果用户输入int行为2,则输出应为{60,70,80,90,100,10 ,20,30,40,50}我该怎么做?

1 个答案:

答案 0 :(得分:0)

如果没有代表Line对象的特殊类,则可以使用regex来解析字符串。在这种情况下,我使用name capture group中的Regex

List<string> elements = new List<string>
{
    "Line 1 int 1",
    "Line 2 int 1",
    "Line 1 int 2",
    "Line 1 int 3",
    "Line 2 int 2",
    "Line 2 int 12",
};

var pattern = @"^\bLine \b(?<num1>\d+) \bint \b(?<num2>\d+)$";
Regex regex = new Regex(pattern);

var query =
    from e in elements
    where regex.Match(e).Success
    orderby 
        int.Parse(regex.Match(e).Groups["num1"].Value), 
        int.Parse(regex.Match(e).Groups["num2"].Value)
    select e;

var orderedResult = query.ToList();

或与流畅的API LINQ相同:

var orderedResult =
        elements
            .Where(e => regex.Match(e).Success)
            .OrderBy(e => int.Parse(regex.Match(e).Groups["num1"].Value))
            .ThenBy(e => int.Parse(regex.Match(e).Groups["num2"].Value))
            .ToList();

orderedResult应该是:

Line 1 int 1 
Line 1 int 2 
Line 1 int 3 
Line 2 int 1 
Line 2 int 2 
Line 2 int 12 

更新:

创建一个类和扩展方法,将您的列表分成多个块:

public static class MyLinqExtensions
{
    public static IEnumerable<IEnumerable<T>> Batch<T>(
        this IEnumerable<T> source, int batchSize)
    {
        using (var enumerator = source.GetEnumerator())
            while (enumerator.MoveNext())
                yield return YieldBatchElements(enumerator, batchSize - 1);
    }

    private static IEnumerable<T> YieldBatchElements<T>(
        IEnumerator<T> source, int batchSize)
    {
        yield return source.Current;
        for (int i = 0; i < batchSize && source.MoveNext(); i++)
            yield return source.Current;
    }
}

此代码取自this answer

然后,您可以通过以下方式使用Batch扩展方法:

List<int> coord = new List<int> { 80, 90, 100, 60, 70, 20, 40, 30, 10, 50 };

int n = 5;
var orderedResult = 
    coord.Batch(n)
        .Select(b => b.OrderBy(i => i))
        .SelectMany(x => x)
        .ToList();

如果您想学习LINQ, LINQPad 是您的朋友。