Java에서 CSV 파일에 문자열 쓰기

Rupam Yadav 2023년10월12일
  1. PrintWriter를 사용하여 Java에서 CSV 파일 읽기 및 쓰기
  2. OpenCSV라이브러리를 사용하여 Java에서 CSV 파일 읽기 및 쓰기
Java에서 CSV 파일에 문자열 쓰기

CSV는Comma Separated Values를 의미합니다. 시스템 간의 대용량 데이터 전송에 일반적으로 사용되는 형식입니다. 이 형식으로 작업 할 수 있도록 Java와 함께 사용할 파서 라이브러리도 많이 있습니다.

PrintWriter를 사용하여 Java에서 CSV 파일 읽기 및 쓰기

Java의PrinterWriter함수는 개체의 형식화 된 표현을 텍스트 출력 스트림으로 인쇄하는 데 사용되는 작성기 클래스입니다. 작성자의 대상으로test.csv라는 새 파일을 전달하는writer개체를 만듭니다. 여기서sb개체는 지정된 문자열을 문자 시퀀스에 추가합니다.

writer인스턴스의write()메서드는 텍스트 콘텐츠를 스트림에 씁니다. flush()메소드는 내용을 파일로 플러시하고close()메소드는 스트림을 영구적으로 닫습니다. test.csv파일의 내용도 읽을 수 있습니다.

readCSVFile()메소드는TestCSV클래스 인스턴스에서 호출됩니다. 여기서는 지정된 파일의 값을 사용하여Scanner클래스의 인스턴스를 만들었습니다. 구분 기호 패턴을 사용하여 데이터를 토큰으로 나눕니다. hasNextLine()은 스캐너에 다른 입력 줄이 있으면 true를 반환합니다. 따라서next()메소드를 사용하여 토큰 데이터의 각 라인을 읽고이를 배열에 저장하고 마지막으로 출력을 인쇄합니다.

import java.io.File;
import java.io.FileNotFoundException;
import java.io.PrintWriter;
import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;

public class TestCSV {
  public static void main(String args[]) {
    try (PrintWriter writer = new PrintWriter(new File("test.csv"))) {
      StringBuilder sb = new StringBuilder();
      sb.append("id");
      sb.append(',');
      sb.append("Name");
      sb.append(',');
      sb.append("Address");
      sb.append('\n');

      sb.append("101");
      sb.append(',');
      sb.append("John Doe");
      sb.append(',');
      sb.append("Las Vegas");
      sb.append('\n');

      writer.write(sb.toString());
      writer.close();
      System.out.println("done!");

    } catch (FileNotFoundException e) {
      System.out.println(e.getMessage());
    }
    TestCSV testCSV = new TestCSV();
    testCSV.readCSVFile();
  }

  public void readCSVFile() {
    List<List<String>> records = new ArrayList<>();
    try (Scanner scanner = new Scanner(new File("test.csv"));) {
      while (scanner.hasNextLine()) {
        records.add(getRecordFromLine(scanner.nextLine()));
      }
    } catch (FileNotFoundException e) {
      e.printStackTrace();
    }
    System.out.println(records.toString());
  }
  private List<String> getRecordFromLine(String line) {
    List<String> values = new ArrayList<String>();
    try (Scanner rowScanner = new Scanner(line)) {
      rowScanner.useDelimiter(",");
      while (rowScanner.hasNext()) {
        values.add(rowScanner.next());
      }
    }
    return values;
  }
}

출력:

done!
[[id, Name, Address], [101, John Doe, Las Vegas]]

OpenCSV라이브러리를 사용하여 Java에서 CSV 파일 읽기 및 쓰기

이 라이브러리에 대한 maven 종속성은 다음과 같습니다.

 <dependency>
      <groupId>com.opencsv</groupId>
      <artifactId>opencsv</artifactId>
      <version>5.4</version>
 </dependency>

OpenCsv는 자바 용 간단한 파서 라이브러리입니다. CSV 파일을 읽고 쓰는 데 사용하는 OpenCsv 클래스 세트가 있습니다. main()메소드에서 먼저CSVWriter클래스를 사용하여 CSV 파일에 쓰는 메소드를 호출합니다. 이 클래스는 CSV 데이터를 작성기 구현에 쓰는 데 사용됩니다.

CSVWriterwriter인스턴스를 만들고이 개체에 대해writeNext()함수를 호출하여 구분 기호를 사용하여 분리 된 문자열 배열의 데이터가 포함 된 CSV 파일을 생성합니다. close()메소드는 기록기 스트림을 닫습니다.

CSV 형식으로 만든 파일에서 데이터를 읽기 위해 CSV 파일을 구문 분석하는 메인 클래스 개체에서readCSVFile메서드를 호출합니다. 모든 레코드를 한 번에 목록으로 읽으려면readAll()메서드를 사용합니다. 각 레코드를 반복하고 인쇄합니다.

import com.opencsv.CSVReader;
import com.opencsv.CSVWriter;
import com.opencsv.exceptions.CsvException;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
import java.util.Arrays;
import java.util.List;

public class CSVLibrary {
  public static void main(String args[]) {
    CSVLibrary csvLibrary = new CSVLibrary();
    csvLibrary.writeToCsv();
    csvLibrary.readCSVFile();
  }
  public void writeToCsv() {
    String csv = "data.csv";
    try {
      CSVWriter writer = new CSVWriter(new FileWriter(csv));
      String[] record = "2,Virat,Kohli,India,30".split(",");
      writer.writeNext(record);

      writer.close();
    } catch (IOException e) {
      e.printStackTrace();
    }
  }
  public void readCSVFile() {
    CSVReader reader = null;
    try {
      reader = new CSVReader(new FileReader("data.csv"));
    } catch (FileNotFoundException e) {
      e.printStackTrace();
    }

    List<String[]> allRows = null;
    try {
      allRows = reader.readAll();
    } catch (IOException e) {
      e.printStackTrace();
    } catch (CsvException e) {
      e.printStackTrace();
    }

    for (String[] row : allRows) {
      System.out.println(Arrays.toString(row));
    }
  }
}

출력:

[2, Virat, Kohli, India, 30]
작가: Rupam Yadav
Rupam Yadav avatar Rupam Yadav avatar

Rupam Saini is an android developer, who also works sometimes as a web developer., He likes to read books and write about various things.

LinkedIn

관련 문장 - Java CSV

관련 문장 - Java String