?
Solved

how to sort an arraylist by column?

Posted on 2004-08-25
20
Medium Priority
?
253 Views
Last Modified: 2012-08-14
experts,

I need to sort an ArrayList of an OBject, which contains column A, B, C. I need to sort by column C of this object, how to do this? tried and no luck.

thanks.




0
Comment
Question by:panpanW
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 12
  • 5
  • 2
  • +1
20 Comments
 
LVL 35

Expert Comment

by:girionis
ID: 11894870
I am not sure I understand fully. What exactly do you mean "contains column A, B, C"? Can you elaborate?


Regards
0
 
LVL 86

Expert Comment

by:CEHJ
ID: 11895097
You probably mean a List of ArrayList. You can use a custom Comparator:

import java.util.*;

public class ColumnSorter implements Comparator {
  int columnIndex;

  public ColumnSorter(int columnIndex) {
    this.columnIndex = columnIndex;
  }

  public int compare(Object o1, Object o2) {
    //return ((int[])o1)[columnIndex] - ((int[])o2)[columnIndex];
    java.util.List list1 = (java.util.List)o1;
    java.util.List list2 = (java.util.List)o2;
    return ((Comparable)list1.get(columnIndex)).compareTo((Comparable)list2.get(columnIndex));
  }

}



0
 
LVL 86

Assisted Solution

by:CEHJ
CEHJ earned 240 total points
ID: 11895115
This assumes that the Lists contain elements that are Comparable (usually the case). You can use the class as follows:

Collections.sort(yourListOfLists, new ColumnSorter(2)); // sort by column 2
0
Optimize your web performance

What's in the eBook?
- Full list of reasons for poor performance
- Ultimate measures to speed things up
- Primary web monitoring types
- KPIs you should be monitoring in order to increase your ROI

 

Author Comment

by:panpanW
ID: 11895186
thanks, what do you mean by Comparable?

0
 
LVL 86

Expert Comment

by:CEHJ
ID: 11895287
Things like String, Integer, Date are Comparable
0
 
LVL 86

Expert Comment

by:CEHJ
ID: 11895292
What will your ArrayList contain?
0
 

Author Comment

by:panpanW
ID: 11895379
class test {

int a
string b
}
0
 
LVL 86

Accepted Solution

by:
CEHJ earned 240 total points
ID: 11895446
OK. In that case, make it Comparable:


class Test implements Comparable {

      int a;
      String b;
      
      .....
      
      public int compareTo(Object other) {
            Test otherTest = (Test)other;
            return this.a - otherTest.a;
            // (Or however you want to sort them)
      }
}

0
 
LVL 86

Expert Comment

by:CEHJ
ID: 11895455
(That would sort on field 'a')
0
 
LVL 92

Expert Comment

by:objects
ID: 11898112
If the above comments have answered your question then please accept an answer, if not then post your further questions and we shall attempt to assist you further.
0
 

Author Comment

by:panpanW
ID: 11906156

thanks, but I am trying to put everything together and getting ClassCastException:

   
     public int compareTo(Object other) {
          Test otherTest = (Test)other;
          return this.a - otherTest.a;
          // (Or however you want to sort them)
     }

do you try to minus these two value? so, this will return a number? then, combined with above codes you wrote:

public class ColumnSorter implements Comparator {
  int columnIndex;

  public ColumnSorter(int columnIndex) {
    this.columnIndex = columnIndex;
  }

  public int compare(Object o1, Object o2) {
    //return ((int[])o1)[columnIndex] - ((int[])o2)[columnIndex];
    java.util.List list1 = (java.util.List)o1;
    java.util.List list2 = (java.util.List)o2;
    return ((Comparable)list1.get(columnIndex)).compareTo((Comparable)list2.get(columnIndex));
  }

}

Collections.sort(yourListOfLists, new ColumnSorter(2));
*********************************************
don't know why is getting ClassCastException??? thanks.l
0
 
LVL 86

Expert Comment

by:CEHJ
ID: 11906190
Have you made your Test class Comparable?
0
 
LVL 86

Expert Comment

by:CEHJ
ID: 11906197
>>do you try to minus these two value? so, this will return a number?

Yes and yes
0
 

Author Comment

by:panpanW
ID: 11906241
i did. it looks like the exception comes from

public int compare(Object o1, Object o2) {
    //return ((int[])o1)[columnIndex] - ((int[])o2)[columnIndex];
    List list1 = (List)o1;
    List list2 = (List)o2;
    return ((Comparable)list1.get(columnIndex)).compareTo((Comparable)list2.get(columnIndex));
  }
0
 
LVL 86

Expert Comment

by:CEHJ
ID: 11906294
OK. As the first two lines of that method, do

System.out.println(o1.getClass());
System.out.println(o2.getClass());
0
 
LVL 86

Expert Comment

by:CEHJ
ID: 11906304
Oh and get rid of that commented-out line i stupidly left in ;-)
0
 

Author Comment

by:panpanW
ID: 11906385
it returns the "test" class, not the ArrayList of test....
0
 
LVL 86

Assisted Solution

by:CEHJ
CEHJ earned 240 total points
ID: 11906442
OK. You must have one dimension then. Just make this the method body:

    Comparable test1 = (Comparable)o1;
    Comparable test2 = (Comparable)o2;
    return test1.compareTo(test2);
0
 
LVL 86

Expert Comment

by:CEHJ
ID: 11911014
:-)
0
 
LVL 92

Expert Comment

by:objects
ID: 11918374
Thanks for closing the question :)
0

Featured Post

Get real performance insights from real users

Key features:
- Total Pages Views and Load times
- Top Pages Viewed and Load Times
- Real Time Site Page Build Performance
- Users’ Browser and Platform Performance
- Geographic User Breakdown
- And more

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Java had always been an easily readable and understandable language.  Some relatively recent changes in the language seem to be changing this pretty fast, and anyone that had not seen any Java code for the last 5 years will possibly have issues unde…
Basic understanding on "OO- Object Orientation" is needed for designing a logical solution to solve a problem. Basic OOAD is a prerequisite for a coder to ensure that they follow the basic design of OO. This would help developers to understand the b…
Viewers will learn about the different types of variables in Java and how to declare them. Decide the type of variable desired: Put the keyword corresponding to the type of variable in front of the variable name: Use the equal sign to assign a v…
Viewers will learn about the regular for loop in Java and how to use it. Definition: Break the for loop down into 3 parts: Syntax when using for loops: Example using a for loop:
Suggested Courses

770 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question