列表<字符串复杂排序

Listamp;lt;stringamp;gt; complex sorting(列表amp;lt;字符串复杂排序)
本文介绍了列表<字符串复杂排序的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有List<string>个尺寸,比如XS、S、M、L、XL、XXL、UK 10、UK 12等

我想要的是将顺序强制为上面的顺序,而不考虑列表中项的顺序,我认为我需要一个可比较运算符,但不确定。

理想情况下,我希望另一个列表具有正确的顺序,以便它可以引用它在列表中的位置并重新排序,如果它不存在,它将默认为A-Z

推荐答案

按照您希望的大小顺序创建一个尺码数组,然后根据衬衫在该数组中的大小位置对衬衫进行排序:

string[] sizes = new [] {"XS", "S", "M", "L", "XL", "XXL", "UK 10", "UK 12"};

var shirtsInOrder = shirts
                        .OrderBy(s=>sizes.Contains(s) ? "0" : "1")  // put unmatched sizes at the end
                        .ThenBy(s=>Array.IndexOf(sizes,s))  // sort matches by size
                        .ThenBy(s=>s); // sort rest A-Z

这篇关于列表&amp;lt;字符串复杂排序的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

DispatcherQueue null when trying to update Ui property in ViewModel(尝试更新ViewModel中的Ui属性时DispatcherQueue为空)
Drawing over all windows on multiple monitors(在多个监视器上绘制所有窗口)
Programmatically show the desktop(以编程方式显示桌面)
c# Generic Setlt;Tgt; implementation to access objects by type(按类型访问对象的C#泛型集实现)
InvalidOperationException When using Context Injection in ASP.Net Core(在ASP.NET核心中使用上下文注入时发生InvalidOperationException)
LINQ many-to-many relationship, how to write a correct WHERE clause?(LINQ多对多关系,如何写一个正确的WHERE子句?)