在java中使用comparator对文件内容进行排序

在java中使用comparator对文件内容进行排序,java,list,file,sorting,Java,List,File,Sorting,我已经通过ArrayList添加了文件的内容,现在我需要对这些内容进行排序,然后将它们放回文件中。我怎么做 package training; import java.io.*; import java.util.Collections; /* method to create a file, store the contents of list and write read them back */ public class FileCreation implements Serializa

我已经通过ArrayList添加了文件的内容,现在我需要对这些内容进行排序,然后将它们放回文件中。我怎么做

package training;
import java.io.*;
import java.util.Collections;
/* method to create a file, store the contents of list and write read them back
*/

public class FileCreation implements Serializable {
    public void filesPatient(Person p) throws ClassNotFoundException {

        String Filename = "PatientDetails.txt";
        try {
            ObjectOutputStream os = new ObjectOutputStream(
                    new FileOutputStream(Filename));
            os.writeObject(p);
            os.close();
        } catch (Exception e) {

        }
        System.out.println("Done wRiting");
        try {
            ObjectInputStream is = new ObjectInputStream(new FileInputStream(
                    Filename));
            Person l = (Person) is.readObject();
            System.out.println("*****************Patient Details*************");
            System.out.println("Name : " + l.getName() + "\nID: " + l.getId()
                    + "\nGender: " + l.getGender());
            System.out.println();

        } catch (FileNotFoundException e) {
            // TODO Auto-generated catch block

            e.printStackTrace();
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }

}

请帮助我找到合适的方法进行排序。

如果要按默认字符串值排序,可以使用Collections.sort方法:

Collections.sort( list );
否则,您可以编写自己的比较器来执行自己的特定排序逻辑。有关更多示例/说明,请查看此帖子:

编辑

我相信你在找这样的东西。注意:为了对ArrayList进行排序,您必须将整个列表加载到内存中,然后对其进行排序,然后将整个列表写入文件,因此请确保列表不会太长,并且适合内存

ArrayList<Person> arrlist = new ArrayList<Person>(2);
while(more Person data exists) { // Replace this with however you are loading your data
    p = new Person();
    p.getdata();
    arrlist.add(p);
}

Collections.sort(arrList); // now your list is sorted

for(Person p : arrList) { 
    fc.filesPatient(p);  // add all your patients to file, from your list which is now sorted
}
ArrayList arrlist=新的ArrayList(2);
虽然(存在更多的人员数据){//但将其替换为加载数据的方式
p=新人();
p、 getdata();
增加(p);
}
Collections.sort(arrList);//现在您的列表已排序
对于(个人p:arrList){
fc.filescient(p);//从现在已排序的列表中将所有患者添加到文件中
}
ArrayList arrlist=新的ArrayList(2);
p=新人();
p、 getdata();
增加(p);
fc患者(p);
p=新人();
p、 getdata();
增加(p);
fc患者(p);

FYI在谈到排序时,查看管理ArrayList的代码比管理文件I/ODo的代码更有用。您真的想在该类中实现可序列化吗?您的问题是否更倾向于如何使文件具有可读性?正如@Matt所说,要对集合中的内容进行排序,您需要在这里添加您在答案中使用的代码。但是无论如何,你可能想先读所有的人,然后把他们添加到arraylist中,只有在你读了所有的东西之后,你才会对Collecions进行排序(arrlist);然后从数组列表中的顺序开始写入。。我就是这样做的..ArrayList arrlist=new ArrayList(2);p=新人();p.getdata();增加(p);fc患者(p);p=新人();p.getdata();增加(p);fc患者(p);我使用的是arrayList而不是HashMap。我不知道如何将对象传递给比较器,以及应该在哪个类中实现它。请帮助..你能解释什么是“更多”和“数据存在”。我想把未排序的对象添加到文件中。。写下未排序的列表。。然后使用comparator执行排序,并将排序后的顺序存储回文件。从何处加载人员数据?
ArrayList<Person> arrlist = new ArrayList<Person>(2);
p = new Person();
p.getdata();
arrlist.add(p);
fc.filesPatient(p);

p = new Person();
p.getdata();
arrlist.add(p);
fc.filesPatient(p);