Java에서 CSV 파일을 읽거나 쓸 때 OpenCsv라는 라이브러리를 사용할 수 있습니다. 물론, 간단한 CSV 파일을 만드신다면 직접 구현하실 수도 있습니다.
저는 간단한 CSV 파일만 생성하려고 했기 때문에, 읽고/쓰는 방법만 구현해보았습니다. 사이트에 들어가서 예제를 보시면, 고급스러운 방법으로 효율적인 CSV 파일을 만들 수 있도록 가이드를 합니다.
OpenCsv의 고급 기능을 사용하신다면 OpenCsv를 참고하시면 좋을 것 같습니다.
라이브러리 설정
저는 Gradle로 프로젝트를 만들었습니다. gradle을 사용하시면 다음과 같이 의존성을 설정하시면 됩니다.
dependencies {
...
implementation group: 'com.opencsv', name: 'opencsv', version: '4.4'
}
Write CSV
다음은 CSV 파일을 만드는 예제입니다.
package example;
import com.opencsv.CSVReader;
import com.opencsv.CSVWriter;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
public class OpenCsv {
public static void writeDataToCsv(String filePath) throws IOException {
CSVWriter writer = new CSVWriter(new FileWriter(filePath));
String[] entries = "EW#City#State".split("#"); // 1
writer.writeNext(entries); // 2
String[] entries1 = {"W", "Youngstown", "OH"}; // 3
writer.writeNext(entries1);
String[] entries2 = {"W", "Williamson", "WV"};
writer.writeNext(entries2);
writer.close();
}
public static void main(String args[]) throws IOException {
writeDataToCsv("./sample.csv");
}
}
- split()을 이용하여 문자열 배열을 만들 수 있습니다.
writeNext()
을 호출하면 인자가 CSV 파일에 저장이 됩니다.- 직접 배열에 아이템을 넣어도 됩니다.
생성된 파일의 내용은 다음과 같습니다.
"EW","City","State"
"W","Youngstown","OH"
"W","Williamson","WV"
Read CSV
다음은 CSV 파일을 만들고, CSV 파일을 읽어서 데이터를 출력하는 예제입니다.
package example;
import com.opencsv.CSVReader;
import com.opencsv.CSVWriter;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
public class OpenCsv {
public static void writeDataToCsv(String filePath) throws IOException {
CSVWriter writer = new CSVWriter(new FileWriter(filePath));
String[] entries = "EW#City#State".split("#"); // 1
writer.writeNext(entries);
String[] entries1 = {"W", "Youngstown", "OH"}; // 2
writer.writeNext(entries1);
String[] entries2 = {"W", "Williamson", "WV"};
writer.writeNext(entries2);
writer.close();
}
public static void readDataFromCsv(String filePath) throws IOException {
CSVReader reader = new CSVReader(new FileReader(filePath)); // 1
String [] nextLine;
while ((nextLine = reader.readNext()) != null) { // 2
for (int i = 0; i < nextLine.length; i++) {
System.out.println(i + " " + nextLine[i]);
}
System.out.println();
}
}
public static void main(String args[]) throws IOException {
writeDataToCsv("./sample.csv");
readDataFromCsv("./sample.csv");
}
}
- CSVReader를 생성합니다.
readNext()
로 CSV 파일을 한줄 씩 읽을 수 있습니다. 아이템 개수만큼 배열이 리턴됩니다.
실행 결과는 다음과 같습니다.
0 EW
1 City
2 State
0 W
1 Youngstown
2 OH
0 W
1 Williamson
2 WV
참고
Loading script...
Related Posts
- Java - Unsupported class file major version 61 에러
- Java - String.matches()로 문자열 패턴 확인 및 다양한 예제 소개
- Java - 문자열 공백제거 (trim, replace)
- Java - replace()와 replaceAll()의 차이점
- Java - ArrayList 초기화, 4가지 방법
- Java - 배열 정렬(Sorting) (오름차순, 내림차순)
- Java - 문자열(String)을 비교하는 방법 (==, equals, compare)
- Java - StringBuilder 사용 방법, 예제
- Java - 로그 출력, 파일 저장 방법 (Logger 라이브러리)
- Java IllegalArgumentException 의미, 발생 이유
- Java - NullPointerException 원인, 해결 방법
- Seleninum의 ConnectionFailedException: Unable to establish websocket connection 해결
- Java - compareTo(), 객체 크기 비교
- Java - BufferedWriter로 파일 쓰기
- Java - BufferedReader로 파일 읽기
- Java charAt() 함수 알아보기
- Java - BigInteger 범위, 비교, 연산, 형변환
- Java contains()로 문자(대소문자 X) 포함 확인
- Java - Set(HashSet)를 배열로 변환
- Java - 문자열 첫번째 문자, 마지막 문자 확인
- Java - 문자열 한글자씩 자르기
- Java - 문자열 단어 개수 가져오기
- Java - 1초마다 반복 실행
- Java - 배열을 Set(HashSet)로 변환
- Java - 여러 Set(HashSet) 합치기
- Java - 명령행 인자 입력 받기
- Java - 리스트 역순으로 순회, 3가지 방법
- Java - 특정 조건으로 리스트 필터링, 3가지 방법
- Java - HashMap 모든 요소들의 합계, 평균 계산
- Java - 특정 조건으로 HashMap 필터링
- Java - 싱글톤(Singleton) 패턴 구현
- Java - 숫자 왼쪽에 0으로 채우기
- Java - String 배열 초기화 방법
- Java - 정렬된 순서로 Map(HashMap) 순회
- Java - HashMap에서 key, value 가져오기