Java를 사용하여 한 줄씩 큰 텍스트 파일을 읽는 방법?


Answers

이 블로그를보십시오 :

버퍼 크기를 지정하거나 기본 크기를 사용할 수 있습니다. 기본값은 대부분의 경우 충분히 큽니다.

// Open the file
FileInputStream fstream = new FileInputStream("textfile.txt");
BufferedReader br = new BufferedReader(new InputStreamReader(fstream));

String strLine;

//Read File Line By Line
while ((strLine = br.readLine()) != null)   {
  // Print the content on the console
  System.out.println (strLine);
}

//Close the input stream
br.close();
Question

Java를 사용하여 5-6 GB 정도의 대용량 텍스트 파일을 한 줄씩 읽어야합니다.

어떻게하면됩니까?




나는 보통 독서 루틴을 간단하게한다.

void readResource(InputStream source) throws IOException {
    BufferedReader stream = null;
    try {
        stream = new BufferedReader(new InputStreamReader(source));
        while (true) {
            String line = stream.readLine();
            if(line == null) {
                break;
            }
            //process line
            System.out.println(line)
        }
    } finally {
        closeQuiet(stream);
    }
}

static void closeQuiet(Closeable closeable) {
    if (closeable != null) {
        try {
            closeable.close();
        } catch (IOException ignore) {
        }
    }
}



다음은 완전한 Java 7 이전 오류 처리 및 지원 charset 스펙을 가진 샘플입니다. Java 7에서는 코드를보다 명확하게 만드는 try-with-resources 구문을 사용할 수 있습니다.

기본 charset을 원한다면 InputStream을 건너 뛰고 FileReader를 사용할 수 있습니다.

InputStream ins = null; // raw byte-stream
Reader r = null; // cooked reader
BufferedReader br = null; // buffered for readLine()
try {
    String s;
    ins = new FileInputStream("textfile.txt");
    r = new InputStreamReader(ins, "UTF-8"); // leave charset out for default
    br = new BufferedReader(r);
    while ((s = br.readLine()) != null) {
        System.out.println(s);
    }
}
catch (Exception e)
{
    System.err.println(e.getMessage()); // handle exception
}
finally {
    if (br != null) { try { br.close(); } catch(Throwable t) { /* ensure close happens */ } }
    if (r != null) { try { r.close(); } catch(Throwable t) { /* ensure close happens */ } }
    if (ins != null) { try { ins.close(); } catch(Throwable t) { /* ensure close happens */ } }
}

그루비 버전은 다음과 같습니다.

File f = new File("textfile.txt");
f.withReader("UTF-8") { br ->
    br.eachLine { line ->
        println line;
    }
}



Java 7 :

String folderPath = "C:/folderOfMyFile";
Path path = Paths.get(folderPath, "myFileName.csv"); //or any text file eg.: txt, bat, etc
Charset charset = Charset.forName("UTF-8");

try (BufferedReader reader = Files.newBufferedReader(path , charset)) {
  while ((line = reader.readLine()) != null ) {
    //separate all csv fields into string array
    String[] lineVariables = line.split(","); 
  }
} catch (IOException e) {
    System.err.println(e);
}



이를 달성하기위한 명확한 방법,

예 :

현재 디렉토리에 dataFile.txt 가있는 경우

import java.io.*;
import java.util.Scanner;
import java.io.FileNotFoundException;

public class readByLine
{
    public readByLine() throws FileNotFoundException
    {
        Scanner linReader = new Scanner(new File("dataFile.txt"));

        while (linReader.hasNext())
        {
            String line = linReader.nextLine();
            System.out.println(line);
        }
        linReader.close();

    }

    public static void main(String args[])  throws FileNotFoundException
    {
        new readByLine();
    }
}

아래와 같이 출력됩니다.




Java 8에서는 Files.lines() 를 사용하는 다른 방법이 있습니다. 입력 소스가 파일이 아니고 ReaderInputStream 과 같이 추상적 인 것일 경우, BufferedReaderlines() 메소드를 통해 라인을 스트리밍 할 수 있습니다.

예 :

try( BufferedReader reader = new BufferedReader( ... ) ) {
  reader.lines().foreach( line -> processLine( line ) );
}

BufferedReader 읽는 각 입력 행에 대해 processLine() 을 호출합니다.




할 수있는 일은 스캐너를 사용하여 전체 텍스트를 스캔하고 텍스트를 한 줄씩 살펴 보는 것입니다. 물론 다음을 가져와야합니다.

import java.io.File;
import java.io.FileNotFoundException;
import java.util.Scanner;
public static void readText throws FileNotFoundException {
    Scanner scan = new Scanner(new File("samplefilename.txt"));
    while(scan.hasNextLine()){
        String line = scan.nextLine();
        //Here you can manipulate the string the way you want
    }
}

스캐너는 기본적으로 모든 텍스트를 스캔합니다. while 루프는 전체 텍스트를 통과하는 데 사용됩니다.

.hasNextLine() 함수는 텍스트에 더 많은 행이 있으면 true를 반환하는 부울 값입니다. .nextLine() 함수는 전체 행을 문자열로 제공하며 원하는대로 사용할 수 있습니다. System.out.println(line) 을 사용해 텍스트를 인쇄하십시오.

사이드 참고 : .txt는 파일 형식 텍스트입니다.




스트림을 사용하여보다 정확하게 할 수 있습니다.

Files.lines(Paths.get("input.txt")).forEach(s -> stringBuffer.append(s);



apache commons io 사용할 수도 있습니다 :

File file = new File("/home/user/file.txt");
try {
    List<String> lines = FileUtils.readLines(file);
} catch (IOException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
}



자바 8로 파일 읽기

  package com.java.java8;

    import java.nio.file.Files;
    import java.nio.file.Paths;
    import java.util.stream.Stream;

    /**
     * The Class ReadLargeFile.
     *
     * @author Ankit Sood Apr 20, 2017
     */
    public class ReadLargeFile {

        /**
         * The main method.
         *
         * @param args
         *            the arguments
         */
        public static void main(String[] args) {
        try {
            Stream<String> stream = Files.lines(Paths.get("C:\\Users\\System\\Desktop\\demoData.txt"));
            stream.forEach(System.out::println);
        } catch (Exception e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        }
    }



Links