일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 캡슐화
- c#
- 소스 코드
- 강의
- 졸업 작품 소재
- C++
- Windows Forms
- 소켓 통신
- 네트워크 프로그래밍
- 동영상
- 추천
- 알고리즘
- 유튜브 동영상 강의
- 프로젝트
- 언제나휴일
- 클래스 다이어그램
- c언어
- 표준 입출력
- 무료 동영상 강의
- 표준 라이브러리 함수
- 실습
- 동영상 강의
- 원격 제어 프로그램
- 독립기념관
- 산책하기 좋은 곳
- 파이썬
- 실습으로 다지는 c#
- 언제나 휴일
- 충남 천안
- 안드로이드 앱 개발
Archives
- Today
- Total
프로그래밍 언어 및 기술 [언제나휴일]
[실습으로 다지는 C#] CSV 파일 입출력 – StreamReader 클래스 및 StreamWriter 클래스 사용 본문
C#/실습으로 다지는 C#
[실습으로 다지는 C#] CSV 파일 입출력 – StreamReader 클래스 및 StreamWriter 클래스 사용
언휴 2025. 1. 8. 12:00
안녕하세요. 언제나 휴일에 언휴예요.
이번 강의에서는 데이터 분석에서 많이 사용하는 “CSV” 포멧의 파일 입출력을 알아볼게요.
CSV 파일은 데이터를 콤마를 기준으로 열거합니다.
이를 엑셀 등의 프로그램으로 보면 테이블 형태로 확인할 수가 있죠.
여러분들이 CSV 파일 포멧으로 데이터를 기록할 때 주의할 점은 데이터 내용에 콤마가 있다면 다른 문자로 변경한 후에 저장하세요. 만약 이를 유지하길 원한다면 다른 포멧의 파일 입출력을 선택하세요.
실습은 동영상 강의와 소스 코드를 참고하세요.
이번 실습에서는 StreamReader 클래스와 StreamWtirer 클래스를 이용하여 입출력합니다.
Book.cs
namespace StreamReader를_이용한_CSV_포멧_파일_입출력
{
public class Book
{
public string Title
{
get;
private set;
}
public string Desc
{
get;
private set;
}
public string Author
{
get;
private set;
}
public Book(string title,string desc,string author)
{
Title = title;
Desc = desc;
Author = author;
}
public override string ToString()
{
return Title;
}
}
}
BookManager.cs
using System.Collections;
using System.Collections.Generic;
using System.IO;
namespace StreamReader를_이용한_CSV_포멧_파일_입출력
{
public class BookManager: IEnumerable
{
List books = new List();
public void Add(string title, string desc,string author)
{
title = title.Replace(",", " ");
desc = desc.Replace(",", " ");
author = author.Replace(",", " ");
books.Add(new Book(title, desc, author));
}
public void Save()
{
FileStream fs = File.Create("book.csv");
StreamWriter sw = new StreamWriter(fs);
foreach (Book book in books)
{
sw.WriteLine("{0},{1},{2}", book.Title, book.Desc, book.Author);
}
sw.Close();
fs.Close();
}
public void Load()
{
FileStream fs = File.OpenRead("book.csv");
StreamReader sr = new StreamReader(fs);
string s;
string[] sitems;
while(sr.EndOfStream==false)
{
s = sr.ReadLine();
sitems = s.Split(',');
books.Add(new Book(sitems[0], sitems[1], sitems[2]));
}
sr.Close();
fs.Close();
}
public IEnumerator GetEnumerator()
{
return books.GetEnumerator();
}
IEnumerator IEnumerable.GetEnumerator()
{
return books.GetEnumerator();
}
}
}
Program.cs
/* https://ehpub.co.kr
* CSV 포멧 파일 입출력
* StreamReader, StreamWriter 이용 */
using System;
namespace StreamReader를_이용한_CSV_포멧_파일_입출력
{
class Program
{
static void Main(string[] args)
{
BookManager bm = new BookManager();
bm.Add("ABC,123", "알파벳과 숫자에 관하여 설명하는 도서", "알번");
bm.Add("안녕하세요,123", "테스트 프로그램입니다. 그리고, 테스트입니다.", "알번");
bm.Add("디딤돌", "알파벳과 숫자에 관하여 설명하는 도서", "알번");
bm.Add("실습으로 다지는", "알파벳과 숫자에 관하여 설명하는 도서", "알번");
bm.Save();
BookManager bm2 = new BookManager();
bm2.Load();
foreach(Book book in bm2)
{
Console.WriteLine("{0}, {1},{2}", book.Title, book.Desc, book.Author);
}
}
}
}
언제나휴일 여행 및 산책
'C# > 실습으로 다지는 C#' 카테고리의 다른 글
[실습으로 다지는 C#] 런타임에 라이브러리 로딩하여 사용하기 – .NET 리플렉션 (0) | 2025.01.08 |
---|---|
[실습으로 다지는 C#] 학생 키우기 – 학생 구현 및 제어 (0) | 2025.01.08 |
[실습으로 다지는 C#] 콘솔 응용의 기본 제어 – 메뉴로 상호 작용 (0) | 2025.01.08 |
[실습으로 다지는 C#] 콘솔 글자 색 바꾸기 – Windows API 함수 사용 (0) | 2025.01.08 |
[실습으로 다지는 C#]택배 요금 계산 시뮬레이션 (1) | 2025.01.08 |
[실습으로 다지는 C#] 실현 관계(Realization) 실습 (0) | 2025.01.08 |
[실습으로 다지는 C#] 의존(Dependency) 관계 실습 – Part1 (0) | 2025.01.07 |
[실습으로 다지는 C#] 연관 관계(Association) 실습 – 의사, 약사 (1) | 2025.01.07 |