>  기사  >  Java  >  Java에서 텍스트 파일의 마지막 줄을 효율적으로 검색하는 방법은 무엇입니까?

Java에서 텍스트 파일의 마지막 줄을 효율적으로 검색하는 방법은 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-11-07 00:18:02122검색

How to Efficiently Retrieve the Last Lines of a Text File in Java?

Java에서 텍스트 파일의 마지막 줄을 효율적으로 검색

큰 텍스트 파일의 마지막 줄을 읽는 것은 어려운 작업일 수 있으며, 특히 로드를 피하려고 할 때 더욱 그렇습니다. 전체 파일을 메모리에 저장합니다. 이 문서에서는 전체 파일을 탐색하지 않고도 이 작업을 수행하는 두 가지 효율적인 방법을 살펴봅니다.

방법 1: 파일 테일링

첫 번째 방법인 "테일링" ,"에는 파일 끝에 위치를 지정하고 문자별로 뒤로 반복하여 줄 바꿈이 나타날 때까지 문자를 기록하는 작업이 포함됩니다. 이 접근 방식은 파일의 일부만 처리하면 되므로 효율적입니다. 다음 Java 함수는 이 메소드를 구현합니다.

public String tail(File file) {
  try (RandomAccessFile fileHandler = new RandomAccessFile(file, "r")) {
    long fileLength = fileHandler.length() - 1;
    StringBuilder sb = new StringBuilder();

    for (long filePointer = fileLength; filePointer != -1; filePointer--) {
      fileHandler.seek(filePointer);
      int readByte = fileHandler.readByte();

      if (readByte == 0xA) { // line break (LF)
        if (filePointer == fileLength) {
          continue;
        }
        break;

      } else if (readByte == 0xD) { // carriage return (CR)
        if (filePointer == fileLength - 1) {
          continue;
        }
        break;
      }

      sb.append((char) readByte);
    }

    String lastLine = sb.reverse().toString();
    return lastLine;
  } catch (Exception e) {
    e.printStackTrace();
    return null;
  }
}

방법 2: N 라인 테일링

두 번째 메소드는 파일의 마지막 N 라인을 반환하여 첫 번째 메소드를 확장합니다. . 이는 테일링 방법과 유사하게 작동하지만 줄 바꿈을 계산하여 검색할 원하는 줄 수를 결정합니다. 다음 Java 함수는 이 메소드를 구현합니다.

public String tail2(File file, int lines) {
  try (RandomAccessFile fileHandler = new RandomAccessFile(file, "r")) {
    long fileLength = fileHandler.length() - 1;
    StringBuilder sb = new StringBuilder();
    int lineCount = 0;

    for (long filePointer = fileLength; filePointer != -1; filePointer--) {
      fileHandler.seek(filePointer);
      int readByte = fileHandler.readByte();

      if (readByte == 0xA) { // line break (LF)
        if (filePointer < fileLength) {
          lineCount++;
        }
      } else if (readByte == 0xD) { // carriage return (CR)
        if (filePointer < fileLength - 1) {
          lineCount++;
        }
      }

      if (lineCount >= lines) {
        break;
      }

      sb.append((char) readByte);
    }

    String lastLines = sb.reverse().toString();
    return lastLines;
  } catch (Exception e) {
    e.printStackTrace();
    return null;
  }
}

Usage

이러한 메소드는 큰 텍스트 파일의 마지막 줄 또는 마지막 N 줄을 검색하기 위해 호출될 수 있습니다. . 예를 들어, 다음 사용법을 고려하십시오.

File file = new File("D:\stuff\huge.log");
System.out.println(tail(file));
System.out.println(tail2(file, 10));

주의

이 접근 방식은 반전 시 복합 문자의 반전으로 인해 모든 유니코드 문자를 올바르게 처리하지 못할 수 있습니다. . 이 잠재적인 문제에 대한 자세한 내용은 링크된 기사를 참조하세요.

위 내용은 Java에서 텍스트 파일의 마지막 줄을 효율적으로 검색하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.