Microsoft MVP성태의 닷넷 이야기
.NET : 117. CSV 파일을 다루는 방법 [링크 복사], [링크+제목 복사]
조회: 27359
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

.NET에서 CSV 파일을 다루는 방법


물론, ^^ 만들어도 좋습니다. 대신, 진짜로 ", (Comma)"만을 염두에 두고 코딩을 해서는 안 됩니다. 왜냐하면 다음과 같은 데이터들도 나올 수 있기 때문입니다.

"""test""", 1, 5
==> ["test"], [1], [5]

test, "1,5", 6
==> [test], [1,5], [6]

프로그램 공부하는 거라면 느긋하게 하겠지만, 업무 프로그램 만들면서 이런 것까지 신경쓰기에는 시간이 아쉬울 때가 있는데요. 대충 얹혀가는 방법으로 2가지 정도가 있습니다.

첫 번째는, 대부분의 PC에 설치되어 있는 "Microsoft.Jet.OLEDB.4.0" 제공자를 사용하는 것입니다.

C# Tutorial - Using The Built In OLEDB CSV Parser
; http://www.switchonthecode.com/tutorials/csharp-tutorial-using-the-built-in-oledb-csv-parser

DB 처리 방법과 유사하게 CSV 파싱 기능이 제공되기 때문에 그런대로 쓸만한데요. 단점이 하나 있다면, 64비트 운영체제의 경우에 기본적으로 "Microsoft Jet 4.0 OLE DB Provider"가 없다는 것입니다.

32bit/64bit OLE DB Provider
; https://www.sysnet.pe.kr/2/0/558

그렇지만 아쉬워 하지 않아도 됩니다. 두 번째 방법이 있으니. ^^

[C#] CSV 파일 읽어 처리하는 방법 
; http://lifehack.kr/90019935782

간단히, Microsoft.VisualBasic.dll에서 제공되는 TextFieldParser 타입을 사용하시면 됩니다.

위의 2가지 방법 모두, 헤더를 포함할지 여부에 대한 지정 및 별도의 구분자(delimiter)를 지정하는 것도 가능합니다.



[연관 글]






[최초 등록일: ]
[최종 수정일: 6/28/2021]


비밀번호

댓글 작성자
 



2021-04-09 09시01분
JoshClose/CsvHelper - A library for reading and writing CSV files.
; https://github.com/JoshClose/CsvHelper

Cinchoo ETL - CSV Reader
; https://www.codeproject.com/Articles/1145337/Cinchoo-ETL-CSV-Reader
정성태

1  2  3  4  5  [6]  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
1052정성태5/28/200911504.NET 4.0: 9. .NET Framework 4 Client Profile
1050정성태5/21/200912723.NET : 104. 배열 원소 비교
1049정성태5/19/20099605개발 환경 구성: 126. SQL Server 2005/2008 - 가상환경에서의 Clustering 지원
1048정성태5/18/200910283VS.NET IDE : 46. VS 2010 에서의 다양한 T4 사용
1047정성태5/12/200910401Manifest 파일 우선 순위
1046정성태5/9/200910646Debug : 40. .NET 2.0 StackViewer
1045정성태5/7/200918138Windows 2008 : 12. Hyper-V 시스템에서의 표준 비디오 드라이버 설치 고려 - 두 번째 이야기
1044정성태4/23/200919205Windows 2008 : 11. Hyper-V 시스템에서의 표준 비디오 드라이버 설치 고려
1043정성태4/23/200912337Web : 4. 인터넷 익스플로러 8 - InPrivate을 기본 모드로 설정하는 방법
1042정성태4/20/200910703Visual C++ : 16. Thread injection library파일 다운로드1
1041정성태4/10/200910535.NET : 103. FullTrust on the LocalIntranet
1040정성태4/8/200910366TFS : 174. 팀 프로젝트 - Area / Iteration (영역 및 반복) 내보내기/가져오기 도구
1039정성태3/24/20099649.NET : 102. SpicIE - IE Plug-In 프레임워크
1038정성태3/4/20099623VS.NET IDE : 45. Visual Studio를 COM 개체로 제어
1037정성태3/1/200910080.NET 4.0: 8. C# 4.0 - Zip 확장 메서드
1036정성태3/1/200912306TFS : 173. ClickOnce - publish.htm 자동 생성
1035정성태2/27/200911191Windows 2008 : 10. 서버 코어 버전의 IIS 구성 요소 설치 도구 - ocsetup
1034정성태2/27/200910304TFS : 172. TFS 2008과 SQL Server 2005 SP3
1033정성태2/26/200910843SDK : 17. WWSAPI 소개 [1]
1032정성태2/24/200910235.NET : 101. Code Contracts for .NET [1]
1031정성태2/21/20099721.NET : 100. ASP.NET 의 Cache를 일반 응용 프로그램에서도 사용.
1030정성태2/20/200910180.NET : 99. ClickOnce Application 실행 관련 문제점 정리
1029정성태2/19/200910889Visual C++ : 15. MFC Restart Manager Support in VS2010
1028정성태2/10/20099780Windows 2008 : 9. 32-bit optional in Windows Server 2008 R2
1027정성태2/6/200910628Web : 3. Internet Explorer 8 - 보안 (DEP/NX 메모리 보호, ActiveX 보안 개선, 스마트스크린 필터, XSS 필터, 통합 보호)
1026정성태2/4/200910650TFS : 171. Increment your Assembly Versions using Team Build
1  2  3  4  5  [6]  7  8  9  10  11  12  13  14  15  ...