搜索字符串,添加字符串以及删除文件中的字符串

时间:2016-03-03 22:27:59

标签: java file filewriter

我有一个包含人物对象列表的文件。字符串名字,字符串姓氏,& int id。我需要一个方法来对它进行排序,一个向数组添加名称的方法,一个从列表中删除名称的方法,以及一个搜索列表的方法。 更新:这些方法有效但我需要在另一个类的主方法的switch语句中使用这些方法。我需要重命名它们还是我该怎么做?     公共类aList {     字符串fn;     String ln;     int id;     静态人物p;

List<Person> myList = new ArrayList<Person>();

public aList(File fi) throws FileNotFoundException {
    Scanner sc = new Scanner(fi);
    while (sc.hasNext()) {
        fn = sc.next();
        ln = sc.next();
        id = sc.nextInt();
        System.out.println(fn + " " + ln + " " + id);
        p = new Person(fn, ln, id);
        myList.add(p);
    }
    System.out.println("After reading in the file \n");
    for (int i = 0; i < myList.size(); i++) {
        System.out.print(myList.get(i).toString() + "\t");
    }
    System.out.println("\n");
    sc.close();

}

public void sortIt() {
    Collections.sort(myList);
    System.out.println(" After sorting \n");
    for (int i = 0; i < myList.size(); i++) {
        System.out.print(myList.get(i).toString() + "\t");
    }
}

public void add(String name) {
    myList.add(new Person(name, name, id));
}

public void remove(String name) {
    for (Person p : myList) {
        if (p.getName().equals(name)) {
            myList.remove(p);
        } else
            System.out.print("Not a valid name");
    }
}

public Person find(String name) {
    for (Person p : myList) {
        if (p.getName().equals(name)) {
            return p;

        }
    }
    return p;
}

}

1 个答案:

答案 0 :(得分:0)

以下是添加,删除,查找的一些候选人:

    public void add(String name){
        myList.add(new Person(name));//assumes the constructor takes in name param
    }
    public void remove(String name){
        for (Person p : myList){
           if (p.getName().equals(name)){//assumes person class has a getName() method
               myList.remove(p);
           }
    }
    public void find(String name){
        for (Person p : myList){
           if (p.getName().equals(name)){//assumes person class has a getName() method
               return p;
           }
    }

重新排序,但我必须知道你要根据什么排序 - 是字典顺序吗?