我从数据库获取学生信息,
ArrayList<Student> studentList = session.createQuery("from Student order by Date").list();
studentList包含姓名,ID,标记,按日期。我想通过名字显示这个arraylist,因为相同的学生名称包含不同的日期。 如何从arraylist中排序。 Ex studentList值为
1 x 2010-10-01
2 y 2010-10-05
3 z 2010-10-15
1 x 2010-10-10
1 x 2010-10-17
2 y 2010-10-15
4 xx 2010-10-10
我想将其显示为
1 x 2010-10-01
1 x 2010-10-10
1 x 2010-10-17
2 y 2010-10-05
2 y 2010-10-15
3 z 2010-10-15
4 xx 2010-10-10
并将其存储到另一个数组列表
答案 0 :(得分:5)
您需要的方法是:
Collections.sort(List<T>, Comparator<? super T>)
如果Student
类实现Comparable
接口,则可以使用第一种方法。作为旁注,值得考虑的是,您的数据实际上是否应存储在排序的数据结构中,例如SortedMap
(例如TreeMap
实现)。
答案 1 :(得分:5)
有很多问题要看这个答案,例如: https://stackoverflow.com/questions/2784514/sort-arraylist-of-custom-objects-by-property
但这是一个如何做的示例程序。我假设您想先按名称排序,然后按日期排序。您可以在自定义比较器中输入逻辑。
import java.util.*;
public class SortExample {
public static class Student {
public String name;
public String date;
public Student(String name, String date) {
this.name = name;
this.date = date;
}
}
public static class StudentComparator implements Comparator<Student> {
@Override
public int compare(Student s, Student t) {
int f = s.name.compareTo(t.name);
return (f != 0) ? f : s.date.compareTo(t.date);
}
}
public static void main(String args[]) {
ArrayList<Student> l = new ArrayList<Student>(Arrays.asList(
new Student ("x","2010-10-5"),
new Student ("z","2010-10-15"),
new Student ("y","2010-10-05"),
new Student ("x","2010-10-1")
));
System.out.println("Unsorted");
for(Student s : l) {
System.out.println(s.name + " " + s.date);
}
Collections.sort(l, new StudentComparator());
System.out.println("Sorted");
for(Student s : l) {
System.out.println(s.name + " " + s.date);
}
}
}
输出是:
Unsorted
x 2010-10-5
z 2010-10-15
y 2010-10-05
x 2010-10-1
Sorted
x 2010-10-1
x 2010-10-5
y 2010-10-05
z 2010-10-15
编辑:这会对数组列表进行排序。如果您希望将其作为新列表,则必须先将其复制。
答案 2 :(得分:1)
我编写了一个框架,用于按区域设置敏感的顺序对对象的自然语言文本表示进行排序:
http://softsmithy.sourceforge.net/lib/docs/api/org/softsmithy/lib/text/Localizables.html
学生需要实施Localizable 或者您必须通过扩展Localizer来提供StudentLocalizer。
的Maven:
<dependency>
<groupId>org.softsmithy.lib</groupId>
<artifactId>lib-core</artifactId>
<version>0.1</version>
</dependency>
下载:
http://sourceforge.net/projects/softsmithy/files/softsmithy/v0.1/
答案 3 :(得分:1)
测试实施可能是:
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
public class Execute {
public static void main(String args[]) {
List<Student> list = new ArrayList<Student>();
list.add(new Student("TestX"));
list.add(new Student("TestA"));
System.out.println(list);
Collections.sort(list);
System.out.println(list);
}
}
class Student implements Comparable<Student> {
private String name;
public Student() {
super();
}
public Student(String name) {
super();
this.name = name;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Override
public int compareTo(Student student) {
if (this.name == null || student.name == null) {
return 0;
}
return name.compareTo(student.name);
}
@Override
public String toString() {
return name;
}
}