我有一些代码看起来像以下代码之一:
一般来说,它们应该被排序为字符串,但是在“aaa_bbb_d3_aa”和“aaa_bbb_d11_aa”的情况下,前者应该放在第一位,而不是简单的字符串排序。
对排序很重要的数字部分总是位于“_d”或“_c”子字符串之后,并且总是后面跟着“_aa”或“_ac”结束字符串。
Java或SQL中的有效排序算法是什么?
发布于 2015-06-26 23:04:06
最后我得到了NaturalOrderComparator.java:https://github.com/paour/natorder。谢谢@dasblinkenlight的有用评论
发布于 2015-05-29 16:08:37
Collections.sort(yourListOfString, (String a, String b) ->
{
int comparison = Integer.valueOf(a.split("_")[2].replaceAll("[dc]", "")).compareTo(Integer.parseInt(b.split("_")[2].replaceAll("[dc]", "")));
return comparison == 0
? a.split("_")[3].compareTo(b.split("_")[3])
: comparison;
});(我假设你所有的字符串都在一个列表中)
https://stackoverflow.com/questions/30533985
复制相似问题