Разбор файла журнала в Java - PullRequest
2 голосов
/ 20 декабря 2010

All

У меня есть файл журнала с содержанием ниже.

Request from Centercord.
2010-12-14 12:42:13.724 [ 6796] ****************************
2010-12-14 12:42:13.724 [ 6796] 1111111111111111
2010-12-14 12:42:13.724 [ 6796]22222222222

Response from Centercord.
2010-12-14 12:42:21.802 [ 5960] 11111111111111
2010-12-14 12:42:21.802 [ 5960]  ffffffffffffffffffffffffffff
2010-12-14 12:42:21.802 [ 5960]  tttttttttttttttttttttttttttt

Request from Centercord.
2010-12-14 12:42:13.724 [ 6796] ****************************

Мне нужно создать два файла журнала: один для хранения всех деталей запроса, а другой для хранения всех деталей ответа. Как я могу разобрать это и подготовить два файла журнала?.

Мне нужен ответ ниже.

Log 1:

Request from Centercord.
2010-12-14 12:42:13.724 [ 6796] ****************************
2010-12-14 12:42:13.724 [ 6796] 1111111111111111
2010-12-14 12:42:13.724 [ 6796]22222222222

2010-12-14 12:42:13.724 [ 6796] ****************************

Log 2:

Response from Centercord.
2010-12-14 12:42:21.802 [ 5960] 11111111111111
2010-12-14 12:42:21.802 [ 5960]  ffffffffffffffffffffffffffff
2010-12-14 12:42:21.802 [ 5960]  tttttttttttttttttttttttttttt

С уважением, Kanagaraj

Ответы [ 4 ]

9 голосов
/ 20 декабря 2010

Вот как бы я это сделал:

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

public class Test {

    public static void main(String[] args) {

        try {

            PrintWriter requests = new PrintWriter("requests.txt");
            PrintWriter responses = new PrintWriter("responses.txt");
            PrintWriter currentLog = null;

            Scanner s = new Scanner(new File("log.txt"));
            while (s.hasNextLine()) {
                String line = s.nextLine();
                if (line.startsWith("Request from"))
                    currentLog = requests;
                else if (line.startsWith("Response from"))
                    currentLog = responses;
                else if (currentLog != null)
                    currentLog.println(line);
            }

            requests.close();
            responses.close();
            s.close();
        } catch (IOException ioex) {
            // handle exception...
        }
    }
}

Учитывая log.txt

Request from Centercord.
2010-12-14 12:42:13.724 [ 6796] ****************************
2010-12-14 12:42:13.724 [ 6796] 1111111111111111
2010-12-14 12:42:13.724 [ 6796]22222222222

Response from Centercord.
2010-12-14 12:42:21.802 [ 5960] 11111111111111
2010-12-14 12:42:21.802 [ 5960]  ffffffffffffffffffffffffffff
2010-12-14 12:42:21.802 [ 5960]  tttttttttttttttttttttttttttt

Request from Centercord.
2010-12-14 12:42:13.724 [ 6796] ****************************

выдаёт, запросы. Текст

2010-12-14 12:42:13.724 [ 6796] ****************************
2010-12-14 12:42:13.724 [ 6796] 1111111111111111
2010-12-14 12:42:13.724 [ 6796]22222222222

2010-12-14 12:42:13.724 [ 6796] ****************************

... и response.txt

2010-12-14 12:42:21.802 [ 5960] 11111111111111
2010-12-14 12:42:21.802 [ 5960]  ffffffffffffffffffffffffffff
2010-12-14 12:42:21.802 [ 5960]  tttttttttttttttttttttttttttt
0 голосов
/ 20 декабря 2010

Чтобы уменьшить стандартный код, загрузите Google Guava и используйте этот код:

File inputFile = new File("input.log");
File outputLog1 = new File("log1.log");
File outputLog2 = new File("log2.log");

String match1 = "[ 6796]";
String match2 = "[ 5960]";

Files.append("Request from Centercord.\n", outputLog1, Charsets.UTF_8);
Files.append("Response from Centercord.\n", outputLog2, Charsets.UTF_8);

List<String> lines = Files.readLines(inputFile, Charsets.UTF_8);

for (String line : lines) {
    if(line.contains(match1)) Files.append(line + "\n", outputLog1, Charsets.UTF_8);
    if(line.contains(match2)) Files.append(line + "\n", outputLog2, Charsets.UTF_8);
}
0 голосов
/ 20 декабря 2010
StringBuilder requestBuilder = new StringBuilder("Request from Centercord.\n");
StringBuilder responseBuilder = new StringBuilder("Response from Centercord.\n");

boolean isResponse = false;
for (String line:getLinesFromLogFile()) {
  if (line.startsWith("Response")) {
      if(isResponse)
        responseBuilder.append("\n");
      isResponse = true;
  } else if (line.startsWith("Request")) {
      if(!isResponse)
        requestBuilder.append("\n");
      isResponse = false;
  } else {
      if (isResponse) {
         responseBuilder.append(line).append("\n");
      } else {
         requestBuilder.append(line).append("\n");
      }
  }
}

Теперь выгрузите содержимое обоих StringBuilders в целевые файлы.

0 голосов
/ 20 декабря 2010

Вы можете использовать регулярные выражения или RandomAccessFiles, чтобы получить данные так, как вы хотите.

...