用于多列排序的Java比较器?

时间:2012-12-20 09:47:03

标签: java sorting javabeans comparator

是否有任何Java开源比较器用于比较多个字段的bean以进行多列排序?每列可以按升序或降序排序。

对于单列排序,可以使用org.apache.commons.beanutils.BeanComparatororg.springframework.util.comparator.InvertibleComparator一起使用。

我知道这个功能写起来非常简单,但如果它已经编写并经过测试,重新发明轮子有什么好处?

3 个答案:

答案 0 :(得分:7)

几个月前我写了这篇文章。

public abstract class ChainedComparator<T> implements Comparator<T> {

    private Comparator<T> next;

    @Override
    public int compare(T o1, T o2) {
        int result = doCompare(o1, o2);
        if (result == 0) {
            if (getNext() != null) {
                return getNext().compare(o1, o2);
            }
        }

        return result;
    }

    public abstract int doCompare(T o1, T o2);

    public Comparator<T> getNext() {
        return next;
    }

    public void setNext(Comparator<T> next) {
        this.next = next;
    }
}

只需继承此类并覆盖doCompare-Method。然后在setNext()链中设置下一个比较器。比较器越早出现在这个链中,它就越“重要”。

修改

另见我发现的内容:http://commons.apache.org/collections/api-2.1.1/org/apache/commons/collections/comparators/ComparatorChain.html

这是apache commons集合库的一部分,您可以下载here

答案 1 :(得分:1)

JSorter是Java中多列排序的另一种开源替代方案。 http://sourceforge.net/projects/jsorter/

答案 2 :(得分:1)

我最近编写了一个Comparator来对分隔的String记录中的多个字段进行排序。它允许您定义分隔符,记录结构和排序规则(其中一些是特定于类型的)。​​

所需信息以编程方式或通过XML文件播种到Comparator本身。

XML由包嵌入的XSD文件验证。例如,下面是制表符分隔的记录布局,其中包含四个字段(其中两个是可排序的):

<?xml version="1.0" encoding="ISO-8859-1"?> 
<row xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">

    <delimiter>&#009;</delimiter>

    <column xsi:type="Decimal">
        <name>Column One</name>
    </column>

    <column xsi:type="Integer">
        <name>Column Two</name>
    </column>

    <column xsi:type="String">
        <name>Column Three</name>
        <sortOrder>2</sortOrder>
        <trim>true</trim>
        <caseSensitive>false</caseSensitive>        
        <stripAccents>true</stripAccents>
    </column>

    <column xsi:type="DateTime">
        <name>Column Four</name>
        <sortOrder>1</sortOrder>
        <ascending>true</ascending>
        <nullLowSortOrder>true</nullLowSortOrder>
        <trim>true</trim>
        <pattern>yyyy-MM-dd</pattern>
    </column>

</row>

然后你会在java中使用它:

Comparator<String> comparator = new RowComparator(
              new XMLStructureReader(new File("layout.xml")));

图书馆可以在这里找到:

http://sourceforge.net/projects/multicolumnrowcomparator/