푸터 콘텐츠로 바로가기
IRONXL 사용하여

C#에서 쉼표가 포함된 CSV 파일을 읽는 방법

왜 .NET 개발자들이 더 나은 CSV 솔루션이 필요한가요?

CSV 파일은 수많은 .NET 애플리케이션 간의 데이터 교환을 제공합니다. 재무 보고서부터 재고 시스템까지 단 몇 줄의 코드만으로 프로그래밍 방식으로 CSV 파일을 생성할 수 있는 자유를 제공합니다. CsvHelper와 같은 라이브러리는 기본적인 CSV 작업을 다루지만, 현대 개발자는 엑셀 워크북 변환, 내보내기 시 데이터 형식 보존, Enterprise 등급의 스프레드시트 워크플로우 처리와 같은 복잡한 시나리오에 직면합니다. IronXL은 견고한 CSV 작성과 통합된 Excel 기능성을 단일, 종속성 없는 라이브러리로 제공하여 이러한 문제를 해결하며, 다중 열을 쉽게 다루면서 RFC 4180 표준을 준수합니다.

이로 인해 여러 열, 처리 중인 행에만 영향을 미치는 행별 기능, 자동으로 추론된 분리자를 지원하는 맞춤형 .NET CSV 작성기 또는 .NET CSV 파서를 구축하는 개발자에게 이상적입니다.

IronXL 시작하기

NuGet 패키지 관리자를 통해 IronXL 설치는 몇 초 만에 완료됩니다:

Install-Package IronXl.Excel

설치가 완료된 후, IronXL 네임스페이스를 추가하여 CSV 파일을 작성하고 분리된 값을 효율적으로 다루기 시작하세요:

using IronXL;
class Program
{
    static void Main(string[] args)
    {
        // Create a new workbook and worksheet
        WorkBook workBook = WorkBook.Create();
        WorkSheet workSheet = workBook.CreateWorkSheet("data");
        // Add headers
        workSheet["A1"].Value = "Product";
        workSheet["B1"].Value = "Quantity";
        workSheet["C1"].Value = "Price";
        // Add data
        workSheet["A2"].Value = "Widget";
        workSheet["B2"].Value = 100;
        workSheet["C2"].Value = 19.99;
        // Save as CSV with comma delimiter
        workBook.SaveAsCsv("inventory.csv", ",");
    }
}
using IronXL;
class Program
{
    static void Main(string[] args)
    {
        // Create a new workbook and worksheet
        WorkBook workBook = WorkBook.Create();
        WorkSheet workSheet = workBook.CreateWorkSheet("data");
        // Add headers
        workSheet["A1"].Value = "Product";
        workSheet["B1"].Value = "Quantity";
        workSheet["C1"].Value = "Price";
        // Add data
        workSheet["A2"].Value = "Widget";
        workSheet["B2"].Value = 100;
        workSheet["C2"].Value = 19.99;
        // Save as CSV with comma delimiter
        workBook.SaveAsCsv("inventory.csv", ",");
    }
}
$vbLabelText   $csharpLabel

이 간단한 콘솔 테스터 프로그램은 C# 코드에서 직접 CSV 콘텐츠를 작성하고, 데이터를 포함하는 워크북(Workbook) 객체를 생성하는 방법을 보여줍니다. SaveAsCsv 메소드는 기본 분리자(콤마)를 사용하지만, 다른 로케일용 sep를 선택적으로 정의할 수 있습니다; 이것은 특히 10진수 분리자나 대체 열 분리자 문자를 처리할 때 유용합니다. 내부적으로 sep는 출력 버퍼에 대한 배열 할당을 처리합니다. 이전에 언급된 sep 매개변수는 이 문자를 정의할 수 있게 해줍니다.

또한, 정적 진입점을 제공하는 방법을 시연하고, 자원을 정적으로 정의된 풀을 사용하여 효율적인 메모리 관리를 수행하여 여러 행에 걸쳐 높은 성능을 제공하는 방법을 보여주었습니다.

고급 CSV 파일 작성 기법

C#에서 쉼표가 있는 CSV 파일을 읽는 방법: 그림 1 - IronXL로 예제 CSV 출력

고급 CSV 파일 작성 기법

엑셀 워크북을 CSV로 변환

IronXL은 기존 엑셀 파일을 CSV로 변환하고 수식을 평가하며 데이터 무결성을 보장하는 데 탁월합니다. 헤더 행과 동적으로 생성된 데이터를 모두 포함하는 CSV 파일을 작성할 때 필수적입니다.

// Load an Excel file with formulas and formatting
WorkBook workBook = WorkBook.Load("financial_report.xlsx");
// IronXL evaluates formulas before export
workBook.EvaluateAll();
// Export to CSV - each worksheet creates a separate CSV file
workBook.SaveAsCsv("report.csv", ",");
// Creates: report.Sheet1.csv, report.Sheet2.csv, etc.
// Load an Excel file with formulas and formatting
WorkBook workBook = WorkBook.Load("financial_report.xlsx");
// IronXL evaluates formulas before export
workBook.EvaluateAll();
// Export to CSV - each worksheet creates a separate CSV file
workBook.SaveAsCsv("report.csv", ",");
// Creates: report.Sheet1.csv, report.Sheet2.csv, etc.
$vbLabelText   $csharpLabel

다중 시트 워크북을 변환할 때, IronXL은 각 워크시트에 대한 개별 CSV 파일을 자동으로 생성합니다. 수식 계산은 내보내기 전에 실행되어 최종 CSV 출력에 정확한 데이터를 보장합니다. 그러나 이것이 유일한 기능은 아닙니다. 기본적으로 자동으로 추론된 분리자는 지역 간의 호환성을 보장하며, 여러 행 또는 여러 열도 매끄럽게 처리됩니다.

기본적으로 지원되는 분리자가 각기 다른 동적 환경에서는 nullable sep를 사용할 수도 있습니다.

산출

먼저, 여기서 우리는 여러 시트 엑셀 파일에서 생성된 CSV 파일을 볼 수 있습니다:

C#에서 쉼표가 있는 CSV 파일을 읽는 방법: 그림 2 - CSV 파일들

그리고 이것은 엑셀 시트 중 하나와 해당하는 CSV 파일의 예비 비교입니다:

C#에서 쉼표가 있는 CSV 파일을 읽는 방법: 그림 3 - 예제 출력

DataTable을 CSV로 내보내기

데이터베이스 기반 애플리케이션의 경우, IronXL은 DataTable 내보내기를 간소화합니다. 우리는 더 명확하게 하기 위해 일반적인 ref var v 대신 var을 Datarow로 설정하고 있습니다.

// Assume dataTable contains query results
DataTable dataTable = GetSalesData();
WorkBook workBook = WorkBook.Create();
WorkSheet workSheet = workBook.CreateWorkSheet("sales");
// Import DataTable directly
var row = 1;
foreach (var dataRow in dataTable.Rows)
{
    for (var col = 0; col < dataTable.Columns.Count; col++)
    {
        workSheet.SetCellValue(row, col, dataRow[col].ToString());
    }
    row++;
}
// Export with custom delimiter if needed
workBook.SaveAsCsv("sales_data.csv", ";");
// Assume dataTable contains query results
DataTable dataTable = GetSalesData();
WorkBook workBook = WorkBook.Create();
WorkSheet workSheet = workBook.CreateWorkSheet("sales");
// Import DataTable directly
var row = 1;
foreach (var dataRow in dataTable.Rows)
{
    for (var col = 0; col < dataTable.Columns.Count; col++)
    {
        workSheet.SetCellValue(row, col, dataRow[col].ToString());
    }
    row++;
}
// Export with custom delimiter if needed
workBook.SaveAsCsv("sales_data.csv", ";");
$vbLabelText   $csharpLabel

가져올 때, dataTable.Rows 컬렉션의 각 수평 데이터 세트는 워크시트의 새 행이 됩니다. IronXL은 변환하는 동안 데이터 형식을 보존하여, 숫자는 숫자로, 날짜는 형식을 유지하며, 텍스트는 추가 구성 없이 특수 문자를 올바르게 처리합니다.

산출

여기서 우리는 모의 데이터 소스 옆에 있는 출력 CSV 파일을 볼 수 있습니다:

C#에서 쉼표가 있는 CSV 파일을 읽는 방법: 그림 4 - DataTable을 CSV로 내보내기

IronXL 대 CsvHelper: CSV 파일 작성에 대한 옆서 비교

CSV 분석 및 작성 워크플로우를 보여주는 이 직원 데이터 내보내기 시나리오를 고려하세요.

CsvHelper 구현:

using (var writer = new StreamWriter("employees.csv"))
using (var csv = new CsvWriter(writer, CultureInfo.InvariantCulture))
{
    csv.WriteRecords(employees);
}
using (var writer = new StreamWriter("employees.csv"))
using (var csv = new CsvWriter(writer, CultureInfo.InvariantCulture))
{
    csv.WriteRecords(employees);
}
$vbLabelText   $csharpLabel

IronXL 구현:

WorkBook workBook = WorkBook.Create();
WorkSheet workSheet = workBook.CreateWorkSheet("employees");
// Add data with automatic type handling
int rowIndex = 1;
foreach (var emp in employees)
{
    workSheet[$"A{rowIndex}"].Value = emp.Name;
    workSheet[$"B{rowIndex}"].Value = emp.Salary;
    workSheet[$"C{rowIndex}"].Value = emp.StartDate;
    rowIndex++;
}
workBook.SaveAsCsv("employees.csv", ",");
WorkBook workBook = WorkBook.Create();
WorkSheet workSheet = workBook.CreateWorkSheet("employees");
// Add data with automatic type handling
int rowIndex = 1;
foreach (var emp in employees)
{
    workSheet[$"A{rowIndex}"].Value = emp.Name;
    workSheet[$"B{rowIndex}"].Value = emp.Salary;
    workSheet[$"C{rowIndex}"].Value = emp.StartDate;
    rowIndex++;
}
workBook.SaveAsCsv("employees.csv", ",");
$vbLabelText   $csharpLabel

특징

CsvHelper

IronXL

기본적인 CSV 작성

엑셀에서 CSV로 변환

수식 평가

다중 시트 처리

데이터 유형 보존

수동

오토매틱

엑셀 형식 지원

XLSX, XLS, XLSM

MS Office 불필요

CsvHelper는 단순한 열 쓰기 작업을 효율적으로 처리하지만, IronXL은 여러 줄, 보간 문자열, 동적 코드 생성 시나리오와 같은 요소와 함께 일할 수 있는 유연성을 제공하며, ref struct link 같은 구조로 저수준의 최적화까지 허용합니다.

개발자는 특정 기준에 맞는 행을 열거하고, 기본적으로 자동 감지된 구분자를 관리하거나, 단순 콘솔 프로그램으로 행 별 기능을 노출하여 각 항목의 키만 디버깅할 수 있습니다.

Enterprise 기능 및 모범 사례

IronXL의 SaveAsCsv 메서드는 Enterprise급 기능을 포함합니다:

  • 사용자 지정 구분자: 쉼표, 세미콜론, 탭 또는 기타 문자를 지원(기본 구분자는 separator sep로 덮어쓸 수 있음)
  • 인코딩 옵션: UTF-8, UTF-16 및 사용자 정의 인코딩
  • 수식 평가: 내보내기 전에 엑셀 수식을 계산
  • 크로스 플랫폼 지원: Windows, Linux 및 macOS에서 작동

개발자는 확장 메서드를 사용하여 여러 열에 액세스하여 효율적인 처리를 수행하거나, 텍스트 줄바꿈이 필요한 경우 여러 줄에 걸친 CSV 행을 쓸 수 있습니다.

일반적인 문제 및 해결책

CSV 내보내기 작업을 할 때 개발자는 종종 다음과 같은 문제에 직면합니다:

  • 데이터의 특수 문자: IronXL은 자동으로 따옴표, 쉼표 및 줄바꿈을 이스케이프 처리합니다
  • 대용량 파일 처리: 시트 범위를 사용하여 데이터를 청크로 처리
  • 인코딩 문제: 국제 문자를 위해 UTF-8 인코딩 지정
  • 누락된 데이터 유형: IronXL은 기본적으로 숫자 및 날짜 형식을 보존합니다

자세한 문제 해결은 IronXL의 CSV 문서, API 참조, 및 지원 리소스를 참조하십시오.

오늘부터 CSV 작성기를 구축하십시오

IronXL은 CSV 쓰기를 파싱 도전 과제에서 간단한 작업으로 바꿉니다. CSV 기능과 엑셀 워크북 지원, 수식 평가 및 자동 유형 처리를 결합하여 여러 라이브러리를 관리하거나 수작업 데이터 변환의 복잡성을 제거합니다.

CSV 워크플로를 간소화할 준비가 되셨습니까? 무료 체험판을 시작 $liteLicense부터 시작합니다.

자주 묻는 질문

.NET 개발자에게 더 나은 CSV 솔루션이 필요한 이유는 무엇일까요?

.NET 개발자는 쉼표나 특수 문자가 포함된 CSV 파일을 처리할 때 종종 어려움을 겪습니다. IronXL 이러한 복잡성을 손쉽게 처리하는 고급 기능을 제공하여 데이터 구문 분석의 정확성과 효율성을 향상시킵니다.

IronXL CSV 파일에서 따옴표로 묶인 필드를 어떻게 처리하나요?

IronXL 은 따옴표로 묶인 필드가 포함된 CSV 파일을 정확하게 구문 분석하도록 설계되어 쉼표나 기타 특수 문자가 포함된 데이터가 오류 없이 올바르게 해석되고 처리되도록 합니다.

C#에서 CSV 파싱에 IronXL 사용하면 어떤 이점이 있나요?

IronXL 특수 문자, 따옴표로 묶인 필드, 대규모 데이터 세트 등 CSV 파일 파싱을 위한 강력한 기능을 제공합니다. 이를 통해 안정성이 향상되고 개발자가 CSV 관련 문제 디버깅에 소요하는 시간이 줄어듭니다.

IronXL 특수 문자가 포함된 CSV 파일을 처리할 수 있습니까?

네, IronXL 다양한 특수 문자가 포함된 CSV 파일을 처리할 수 있어 구문 분석 오류나 데이터 손실 없이 모든 데이터를 정확하게 읽고 처리할 수 있습니다.

IronXL 다른 CSV 파싱 라이브러리와 다른 점은 무엇인가요?

IronXL 쉼표가 포함된 문자열이나 따옴표로 묶인 필드와 같은 복잡한 CSV 시나리오를 손쉽게 처리하는 능력이 뛰어납니다. 사용자 친화적인 API와 포괄적인 기능을 통해 C#에서 CSV 데이터를 다루는 개발자들에게 선호되는 선택지가 되었습니다.

IronXL 사용하여 대용량 CSV 파일을 처리할 수 있습니까?

IronXL 성능에 최적화되어 있으며 대용량 CSV 파일을 효율적으로 처리할 수 있으므로 방대한 데이터 세트를 다루는 애플리케이션에 적합합니다.

IronXL CSV 데이터 처리의 신뢰성을 어떻게 향상시키나요?

IronXL 쉼표와 특수 문자가 포함된 CSV 파일을 정확하게 처리하여 신뢰성을 높이고, 데이터 구문 분석 중 오류 발생 가능성을 줄이며 데이터 무결성을 보장합니다.

커티스 차우
기술 문서 작성자

커티스 차우는 칼턴 대학교에서 컴퓨터 과학 학사 학위를 취득했으며, Node.js, TypeScript, JavaScript, React를 전문으로 하는 프론트엔드 개발자입니다. 직관적이고 미적으로 뛰어난 사용자 인터페이스를 만드는 데 열정을 가진 그는 최신 프레임워크를 활용하고, 잘 구성되고 시각적으로 매력적인 매뉴얼을 제작하는 것을 즐깁니다.

커티스는 개발 분야 외에도 사물 인터넷(IoT)에 깊은 관심을 가지고 있으며, 하드웨어와 소프트웨어를 통합하는 혁신적인 방법을 연구합니다. 여가 시간에는 게임을 즐기거나 디스코드 봇을 만들면서 기술에 대한 애정과 창의성을 결합합니다.

Iron Support Team

We're online 24 hours, 5 days a week.
Chat
Email
Call Me