Почему чтение только первой строки из текстового файла с использованием итератора <string> - PullRequest
0 голосов
/ 09 сентября 2018

Интерфейс IterableText.

package main;

import java.util.Iterator;

public interface IterableText {

Iterator<String> charIterator();
Iterator<String> wordIterator();
}

FileContent - класс, отвечающий за чтение текстовых файлов. Содержимое предоставляется с помощью методов charIterator() и wordIterator().

Я создал статическую функцию main в классе FileCOntent, потому что я хотел протестировать программу и проверить, все ли работает ...

package main;

import java.io.BufferedReader;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.IOException;
import java.lang.reflect.Array;
import java.util.ArrayList; 
import java.util.Arrays;
import java.util.Iterator;
import java.util.ListIterator;

public class FileContent implements IterableText{

public String pathToFile;
public ArrayList<String> splittedLetters;
public ArrayList<String> splittedWords;

public FileContent(String pathToFile){
    this.pathToFile = pathToFile;
    this.splittedLetters = new ArrayList<String>();
    this.splittedWords = new ArrayList<String>();
}

public Iterator<String> charIterator(){
    try (BufferedReader br = new BufferedReader(new                                                                                                          FileReader(this.pathToFile))) {
        String line;
        while ((line = br.readLine()) != null) {
            String[] splittedText = line.split("");


            for(String letter: splittedText){
                if(!letter.equals(" ")){
                    splittedLetters.add(letter);
                }
            }

            Iterator<String> itr = splittedLetters.iterator();


            while(itr.hasNext()){
                return itr;
            }
        }
    } catch (FileNotFoundException e) {
        e.printStackTrace();
    } catch (IOException e) {
        e.printStackTrace();
    }
    return null;
}

public Iterator<String> wordIterator(){
    try (BufferedReader br = new BufferedReader(new FileReader(this.pathToFile))) {
        String line;
        while ((line = br.readLine()) != null) {
            String[] splittedText = line.split(" ");

            System.out.println(Arrays.toString(splittedText));
            for(String word: splittedText){
                if(!word.equals(" ")){
                    splittedWords.add(word);
                }
            }

            Iterator<String> itr = splittedWords.iterator();



            while(itr.hasNext()){
                return itr;
            }
        }
    } catch (FileNotFoundException e) {
        e.printStackTrace();
    } catch (IOException e) {
        e.printStackTrace();
    }
    return null;
}

public String getFilename(String[] args){
    return args[2];
}


public static void main(String[] args){
    FileContent fileContent = new FileContent("/home/hubert/IdeaProjects/TextAnalysis/src/main/test.txt");
    CharIterator charIterator = new CharIterator(fileContent);

    Iterator<String> itr = fileContent.charIterator();

    while(itr.hasNext()){
        String element = itr.next().toLowerCase();
        System.out.print(element + ", ");
    }

}
}

CharIterator перебирает буквы текста. Реализует next () и hasNext () из интерфейса Iterator.

package main;

import java.util.Iterator;
import java.util.List;
import java.util.Spliterator;
import java.util.Spliterators;
import java.util.stream.Collectors;
import java.util.stream.StreamSupport;

public class CharIterator {

public FileContent fileContent = new FileContent("/home/hubert/IdeaProjects/TextAnalysis/src/main/test.txt");
public int currentIndex = 0;

Iterator<String> itr_string = fileContent.charIterator();
public List<String> ListLetters = StreamSupport.stream(Spliterators.spliteratorUnknownSize(itr_string, Spliterator.ORDERED), false).collect(Collectors.<String> toList());
public String[] arrayLetters = ListLetters.toArray(new String[ListLetters.size()]);

public int currentSize = arrayLetters.length;



public CharIterator(FileContent fileContent){
    this.fileContent = new FileContent(fileContent.pathToFile);
}

public boolean hasNext(){
    return currentIndex < currentSize && arrayLetters[currentIndex] != null;
}

public String next(){
    return arrayLetters[currentIndex++];
}
}

WordIterator перебирает слова текста. Реализует next () и hasNext () из интерфейса Iterator.

package main;

import java.util.*;
import java.util.stream.Collectors;
import java.util.stream.StreamSupport;

public class WordIterator {

public FileContent fileContent = new FileContent("/home/hubert/IdeaProjects/TextAnalysis/src/main/test.txt");
public int currentIndex = 0;


Iterator<String> itr_string = fileContent.charIterator();
public List<String> ListWords = StreamSupport.stream(Spliterators.spliteratorUnknownSize(itr_string, Spliterator.ORDERED), false).collect(Collectors.<String> toList());
public String[] arrayWords = ListWords.toArray(new String[ListWords.size()]);

public int currentSize = arrayWords.length;


public WordIterator(FileContent fileContent){
    this.fileContent = new FileContent(fileContent.pathToFile);
}

public boolean hasNext(){
    return currentIndex < currentSize && arrayWords[currentIndex] != null;
}

public String next(){
    return arrayWords[currentIndex++];
}
}

Можете ли вы сказать мне, почему во время итераций я получаю только первую строку текстового файла ?? В конце каждой строки есть знак: \ n

1 Ответ

0 голосов
/ 09 сентября 2018

Ваш класс FileContent имеет метод charIterator. Он проходит по каждой строке, и в этом цикле вы возвращаетесь.

Итак, ваш цикл никогда не зацикливается.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...