在java中使用comparator对文件内容进行排序
我已经通过ArrayList添加了文件的内容,现在我需要对这些内容进行排序,然后将它们放回文件中。我怎么做在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
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);