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 데이터를 작성기 구현에 쓰는 데 사용됩니다.
CSVWriter
의writer
인스턴스를 만들고이 개체에 대해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 Saini is an android developer, who also works sometimes as a web developer., He likes to read books and write about various things.
LinkedIn