목차
읽기
모든 기록 읽기
수동으로 레코드 읽기
개별 필드 읽기
parse
Write
모든 레코드 쓰기
Mapping
자동 매핑
수동 매핑
참조 매핑
하위 첨자 지정
열 이름 지정
동일 이름 처리
기본값
유형 변환
선택적 유형 변환
ConvertUsing
런타임 매핑
cache achecache 님이 주석을 달리지 않을 것입니다.
Byte count
현재 읽은 바이트 수를 기록합니다. Configuration.Encoding은 CSV 파일과 일치하도록 설정되어야 합니다. 이 설정은 구문 분석 속도에 영향을 미칩니다.
문화 정보
열 번호 변경
Encoding
열 이름 무시 공백
예 열 이름의 공백 무시
비공개 액세스 무시
읽기 예외 무시
읽는 동안 예외가 발생한 후에도 계속 읽기
따옴표 무시
열 이름이 대소문자를 구분하는지 여부
사용자 정의 클래스 매핑에 액세스할 수 있습니다
사용자 정의 클래스의 속성을 찾는 데 사용됩니다
Quote
구분자, 대괄호 또는 줄 끝을 이스케이프하는 데 사용되는 이스케이프 문자를 정의하세요
csv에 쓸 때 모든 필드에 따옴표를 추가할지 여부입니다. QuoteAllFields와 QuoteNoFields는 동시에 true일 수 없습니다.
예외 콜백 읽기
클래스 매핑을 사용하는 경우 등록을 해야 실제로 사용할 수 있습니다.
모든 필드가 비어 있으면 빈 필드로 간주됩니다.
필드 내용 끝의 공백 문자를 제거하세요.
트림 열 이름
빈 필드에서 예외가 발생하는지 여부
유형 변환은 CsvHelper가 문자열을 .NET 유형으로(또는 그 반대로) 변환하는 방법입니다.
예외 정보 보기
DataReader 및 DataTable
DataReader 개체는 CSV
DataTable 개체는 CSV
에 기록됩니다. 관련 기사:
. 넷 CsvHelper 2.0
백엔드 개발 C#.Net 튜토리얼 CSV 파일에 대한 기술 솔루션을 위한 .NET 라이브러리: CsvHelper 중국어 문서

CSV 파일에 대한 기술 솔루션을 위한 .NET 라이브러리: CsvHelper 중국어 문서

Jul 27, 2018 am 11:32 AM
c# csv

CsvHelper는 CSV 파일을 읽고 쓰기 위한 .NET 라이브러리입니다. CsvHelper는 Visual Studio의 패키지 관리자를 통해 다운로드할 수 있습니다. 자동 매핑 정의: 매핑 파일이 제공되지 않으면 기본값은 자동 매핑이며, 이는 클래스의 속성에 순차적으로 매핑됩니다.

GitHub 주소

읽기

모든 기록 읽기

var csv = new CsvReader( textReader );
var records = csv.GetRecords<MyClass>(); // 把 CSV 记录映射到 MyClass,返回的 records 是个 IEnumerable<T> 对象
로그인 후 복사

매핑 관계를 맞춤설정하려면 아래 매핑 섹션을 참조하세요.
레코드는 IEnumerable 개체이므로 액세스할 때만 레코드가 반환되고, 액세스한 후에는 레코드가 반환됩니다. 목록처럼 액세스하려면 다음을 수행하면 됩니다.

var csv = new CsvReader( textReader );
var records = csv.GetRecords<MyClass>().ToList();
로그인 후 복사

수동으로 레코드 읽기

행 루프에서 각 행의 데이터를 읽을 수 있습니다

var csv = new CsvReader( textReader );
while( csv.Read() )
{
    var record = csv.GetRecord<MyClass>();
}
로그인 후 복사

개별 필드 읽기

var csv = new CsvReader( textReader );
while( csv.Read() )
{
    var intField = csv.GetField<int>( 0 );
    var stringField = csv.GetField<string>( 1 );
    var boolField = csv.GetField<bool>( "HeaderName" );
}
로그인 후 복사

읽기 유형이 다음과 같은 경우 예상과 다를 수 있으므로 TryGetField

var csv = new CsvReader( textReader );
while( csv.Read() )
{
    int intField;
    if( !csv.TryGetField( 0, out intField ) )
    {
        // Do something when it can&#39;t convert.
    }
}
로그인 후 복사

parse

를 사용할 수 있습니다. 각 줄을 문자열로 반환하려면 CsvParser를 사용할 수 있습니다.

var parser = new CsvParser( textReader );
while( true )
{
    var row = parser.Read(); // row 是个字符串
    if( row == null )
    {
        break;
    }
}
로그인 후 복사

Write

모든 레코드 쓰기

var csv = new CsvWriter( textWriter );
csv.WriteRecords( records );
로그인 후 복사
var csv = new CsvWriter( textWriter );
foreach( var item in list )
{
    csv.WriteRecord( item );
}
로그인 후 복사
var csv = new CsvWriter( textWriter );
foreach( var item in list )
{
    csv.WriteField( "a" );
    csv.WriteField( 2 );
    csv.WriteField( true );
    csv.NextRecord();
}
로그인 후 복사

Mapping

자동 매핑

매핑 파일이 제공되지 않을 경우 기본값은 자동 매핑이며 자동 매핑은 클래스의 속성에 순서대로 매핑됩니다. 속성이 사용자 정의 클래스인 경우 이 사용자 정의 클래스의 속성에 따라 계속 채워집니다. 순환 참조가 발생하면 자동 매핑이 중지됩니다.

수동 매핑

CSV 파일과 사용자 정의 클래스가 정확히 일치하지 않는 경우 일치하는 클래스를 정의하여 처리할 수 있습니다.

public sealed class MyClassMap : CsvClassMap<MyClass>
{
    public MyClassMap()
    {
        Map( m => m.Id );
        Map( m = > m.Name );
    }
}
로그인 후 복사
이 글은 tangyikejun이 번역했습니다.

참조 매핑

속성이 CSV 파일의 여러 열에 해당하는 사용자 정의 클래스인 경우 참조 매핑을 사용할 수 있습니다.

public sealed class PersonMap : CsvClassMap<Person>
{
    public PersonMap()
    {
        Map( m => m.Id );
        Map( m => m.Name );
        References<AddressMap>( m => m.Address );
    }
}

public sealed class AddressMap : CsvClassMap<Address>
{
    public AddressMap()
    {
        Map( m => m.Street );
        Map( m => m.City );
        Map( m => m.State );
        Map( m => m.Zip );
    }
}
로그인 후 복사

하위 첨자 지정

열 첨자로 매핑을 지정할 수 있습니다

public sealed class MyClassMap : CsvClassMap<MyClass>
{
    public MyClassMap()
    {
        Map( m => m.Id ).Index( 0 );
        Map( m => m.Name ).Index( 1 );
    }
}
로그인 후 복사

열 이름 지정

열 이름으로 매핑을 지정할 수도 있습니다. 이를 위해서는 csv 파일에 헤더 레코드가 있어야 합니다. 즉, 첫 번째 줄에 열 이름

public sealed class MyClassMap : CsvClassMap<MyClass>
{
    public MyClassMap()
    {
        Map( m => m.Id ).Name( "The Id Column" );
        Map( m => m.Name ).Name( "The Name Column" );
    }
}
로그인 후 복사

동일 이름 처리

public sealed class MyClassMap : CsvClassMap<MyClass>
{
    public MyClassMap()
    {
        Map( m => m.FirstName ).Name( "Name" ).NameIndex( 0 );
        Map( m => m.LastName ).Name( "Name" ).NameIndex( 1 );
    }
}
로그인 후 복사

기본값

public sealed class MyClassMap : CsvClassMap<MyClass>
{
    public override void MyClassMap()
    {
        Map( m => m.Id ).Index( 0 ).Default( -1 );
        Map( m => m.Name ).Index( 1 ).Default( "Unknown" );
    }
}
로그인 후 복사

유형 변환

public sealed class MyClassMap : CsvClassMap<MyClass>
{
    public MyClassMap()
    {
        Map( m => m.Id ).Index( 0 ).TypeConverter<MyIdConverter>();
    }
}
로그인 후 복사

선택적 유형 변환

기본 변환기가 대부분의 유형 변환을 처리하지만 때로는 약간의 변경이 필요할 수도 있습니다. 선택적 유형 변환을 사용해 볼 수 있습니다.

public sealed class MyClassMap : CsvClassMap<MyClass>
{
    public MyClassMap()
    {
        Map( m => m.Description ).Index( 0 ).TypeConverterOption( CultureInfo.InvariantCulture ); // 
        Map( m => m.TimeStamp ).Index( 1 ).TypeConverterOption( DateTimeStyles.AdjustToUniversal ); // 时间格式转换
        Map( m => m.Cost ).Index( 2 ).TypeConverterOption( NumberStyles.Currency ); // 数值类型转换
        Map( m => m.CurrencyFormat ).Index( 3 ).TypeConverterOption( "C" );
        Map( m => m.BooleanValue ).Index( 4 ).TypeConverterOption( true, "sure" ).TypeConverterOption( false, "nope" ); // 内容转换
    }
}
로그인 후 복사

ConvertUsing

public sealed class MyClassMap : CsvClassMap<MyClass>
{
    public MyClassMap()
    {
        // 常数
        Map( m => m.Constant ).ConvertUsing( row => 3 );
        // 把两列聚合在一起
        Map( m => m.Aggregate ).ConvertUsing( row => row.GetField<int>( 0 ) + row.GetField<int>( 1 ) );
        // Collection with a single value.
        Map( m => m.Names ).ConvertUsing( row => new List<string>{ row.GetField<string>( "Name" ) } );
        // Just about anything.
        Map( m => m.Anything ).ConvertUsing( row =>
        {
            // You can do anything you want in a block.
            // Just make sure to return the same type as the property.
        } );
    }
}
로그인 후 복사

런타임 매핑

매핑은 런타임에 생성될 수 있습니다.

R
var customerMap = new DefaultCsvClassMap();

// mapping holds the Property - csv column mapping 
foreach( string key in mapping.Keys )
{
    var columnName = mapping[key].ToString();

    if( !String.IsNullOrEmpty( columnName ) )
    {
        var propertyInfo = typeof( Customer ).GetType().GetProperty( key );
        var newMap = new CsvPropertyMap( propertyInfo );
        newMap.Name( columnName );
        customerMap.PropertyMaps.Add( newMap );
    }
}

csv.Configuration.RegisterClassMap(CustomerMap);
로그인 후 복사
re이 기사는 TEXTYIKEJUNFIGURATION 님에 의해 번역되었습니다. 텍스트 스트레더 또는 TextWriter의 읽기 및 쓰기에 대한 해상 매핑
// Default value
csv.Configuration.AllowComments = false;
로그인 후 복사
맵핑
r
var generatedMap = csv.Configuration.AutoMap<MyClass>();
로그인 후 복사

cache achecache 님이 주석을 달리지 않을 것입니다.

// Default value
csv.Configuration.BufferSize = 2048;
로그인 후 복사

Byte count

현재 읽은 바이트 수를 기록합니다. Configuration.Encoding은 CSV 파일과 일치하도록 설정되어야 합니다. 이 설정은 구문 분석 속도에 영향을 미칩니다.

// Default value
csv.Configuration.Comment = &#39;#&#39;;
로그인 후 복사

문화 정보

// Default value
csv.Configuration.CountBytes = false;
로그인 후 복사

Separator

// Default value
csv.Configuration.CultureInfo = CultureInfo.CurrentCulture;
로그인 후 복사

열 번호 변경

활성화하면 열 번호가 변경되면 CsvBadDataException이 발생합니다.

// Default value
csv.Configuration.Delimiter = ",";
로그인 후 복사

Encoding

// Default value
csv.Configuration.DetectColumnCountChanges = false;
로그인 후 복사

헤더 레코드가 있는지 여부

// Default value
csv.Configuration.Encoding = Encoding.UTF8;
로그인 후 복사

열 이름 무시 공백

예 열 이름의 공백 무시

// Default value
csv.Configuration.HasHeaderRecord = true;
로그인 후 복사

비공개 액세스 무시

읽고 쓸 때 비공개 접근자를 무시할지 여부

// Default value
csv.Configuration.IgnoreHeaderWhiteSpace = false;
로그인 후 복사

읽기 예외 무시

읽는 동안 예외가 발생한 후에도 계속 읽기

// Default value
csv.Configuration.IgnorePrivateAccessor = false;
로그인 후 복사

따옴표 무시

따옴표는 이스케이프 문자 역할을 하지 않습니다

// Default value
csv.Configuration.IgnoreReadingExceptions = false;
로그인 후 복사

열 이름이 대소문자를 구분하는지 여부

// Default value
csv.Configuration.IgnoreQuotes = false;
로그인 후 복사

매핑된 액세스

사용자 정의 클래스 매핑에 액세스할 수 있습니다

// Default value
csv.Configuration.IsHeaderCaseSensitive = true;
로그인 후 복사

속성 바인딩 태그

사용자 정의 클래스의 속성을 찾는 데 사용됩니다

var myMap = csv.Configuration.Maps[typeof( MyClass )];
로그인 후 복사

이 문서는 번역되었습니다 by tang yi ke jun

Quote

구분자, 대괄호 또는 줄 끝을 이스케이프하는 데 사용되는 이스케이프 문자를 정의하세요

// Default value
csv.Configuration.PropertyBindingFlags = BindingFlags.Public | BindingFlags.Instance;
로그인 후 복사

모든 필드가 인용됩니다

csv에 쓸 때 모든 필드에 따옴표를 추가할지 여부입니다. QuoteAllFields와 QuoteNoFields는 동시에 true일 수 없습니다.

// Default value
csv.Configuration.Quote = &#39;"&#39;;
로그인 후 복사

따옴표가 없는 모든 필드

QuoteAllFields와 QuoteNoFields는 동시에 true일 수 없습니다.
// Default value
csv.Configuration.QuoteAllFields = false;
로그인 후 복사

예외 콜백 읽기

// Default value
csv.Configuration.QuoteNoFields = false;
로그인 후 복사

클래스 매핑 등록

클래스 매핑을 사용하는 경우 등록을 해야 실제로 사용할 수 있습니다.

csv.Configuration.ReadingExceptionCallback = ( ex, row ) =>
{
    // Log the exception and current row information.
};
로그인 후 복사

빈 기록 건너뛰기

모든 필드가 비어 있으면 빈 필드로 간주됩니다.

csv.Configuration.RegisterClassMap<MyClassMap>();
csv.Configuration.RegisterClassMap<AnotherClassMap>();
로그인 후 복사

필드 자르기

필드 내용 끝의 공백 문자를 제거하세요.

// Default value
csv.Configuration.SkipEmptyRecords = false;
로그인 후 복사

트림 열 이름

// Default value
csv.Configuration.TrimFields = false;
로그인 후 복사

Unbind 클래스 맵

// Default value
csv.Configuration.TrimHeaders = false;
로그인 후 복사

빈 필드에서 예외가 발생하는지 여부

// Unregister single map.
csv.Configuration.UnregisterClassMap<MyClassMap>();
// Unregister all class maps.
csv.Configuration.UnregisterClassMap();
로그인 후 복사

유형 변환

유형 변환은 CsvHelper가 문자열을 .NET 유형으로(또는 그 반대로) 변환하는 방법입니다.

기타

예외 정보 보기

// Default value
csv.Configuration.WillThrowOnMissingField = true;
로그인 후 복사

DataReader 및 DataTable

DataReader 개체는 CSV

Exception.Data["CsvHelper"]

// Row: &#39;3&#39; (1 based)
// Type: &#39;CsvHelper.Tests.CsvReaderTests+TestBoolean&#39;
// Field Index: &#39;0&#39; (0 based)
// Field Name: &#39;BoolColumn&#39;
// Field Value: &#39;two&#39;
로그인 후 복사

DataTable 개체는 CSV

var hasHeaderBeenWritten = false;
while( dataReader.Read() )
{
    if( !hasHeaderBeenWritten )
    {
        for( var i = 0; i < dataReader.FieldCount; i++ )
        {
            csv.WriteField( dataReader.GetName( i ) );
        }
        csv.NextRecord();
        hasHeaderBeenWritten = true;
    }

    for( var i = 0; i < dataReader.FieldCount; i++ )
    {
        csv.WriteField( dataReader[i] );
    }
    csv.NextRecord();
}
로그인 후 복사

CSV에 DataTable

using( var dt = new DataTable() )
{
    dt.Load( dataReader );
    foreach( DataColumn column in dt.Columns )
    {
        csv.WriteField( column.ColumnName );
    }
    csv.NextRecord();

    foreach( DataRow row in dt.Rows )
    {
        for( var i = 0; i < dt.Columns.Count; i++ )
        {
            csv.WriteField( row[i] );
        }
        csv.NextRecord();
    }
}
로그인 후 복사

에 기록됩니다. 관련 기사:

. 넷 CsvHelper 2.0

jQuery EasyUI API 중국어 문서 - Documentation Documentation_jquery

관련 동영상:


Ruby 중국어 문서

위 내용은 CSV 파일에 대한 기술 솔루션을 위한 .NET 라이브러리: CsvHelper 중국어 문서의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

C#을 사용한 Active Directory C#을 사용한 Active Directory Sep 03, 2024 pm 03:33 PM

C#을 사용한 Active Directory 가이드. 여기에서는 소개와 구문 및 예제와 함께 C#에서 Active Directory가 작동하는 방식에 대해 설명합니다.

C# 직렬화 C# 직렬화 Sep 03, 2024 pm 03:30 PM

C# 직렬화 가이드. 여기에서는 C# 직렬화 개체의 소개, 단계, 작업 및 예제를 각각 논의합니다.

C#의 난수 생성기 C#의 난수 생성기 Sep 03, 2024 pm 03:34 PM

C#의 난수 생성기 가이드입니다. 여기서는 난수 생성기의 작동 방식, 의사 난수 및 보안 숫자의 개념에 대해 설명합니다.

C# 데이터 그리드 보기 C# 데이터 그리드 보기 Sep 03, 2024 pm 03:32 PM

C# 데이터 그리드 뷰 가이드. 여기서는 SQL 데이터베이스 또는 Excel 파일에서 데이터 그리드 보기를 로드하고 내보내는 방법에 대한 예를 설명합니다.

C#의 패턴 C#의 패턴 Sep 03, 2024 pm 03:33 PM

C#의 패턴 가이드. 여기에서는 예제 및 코드 구현과 함께 C#의 패턴 소개 및 상위 3가지 유형에 대해 설명합니다.

C#의 소수 C#의 소수 Sep 03, 2024 pm 03:35 PM

C#의 소수 가이드. 여기서는 코드 구현과 함께 C#의 소수에 대한 소개와 예를 논의합니다.

C#의 팩토리얼 C#의 팩토리얼 Sep 03, 2024 pm 03:34 PM

C#의 팩토리얼 가이드입니다. 여기서는 다양한 예제 및 코드 구현과 함께 C#의 계승에 대한 소개를 논의합니다.

멀티 스레딩과 비동기 C#의 차이 멀티 스레딩과 비동기 C#의 차이 Apr 03, 2025 pm 02:57 PM

멀티 스레딩과 비동기식의 차이점은 멀티 스레딩이 동시에 여러 스레드를 실행하는 반면, 현재 스레드를 차단하지 않고 비동기식으로 작업을 수행한다는 것입니다. 멀티 스레딩은 컴퓨팅 집약적 인 작업에 사용되며 비동기식은 사용자 상호 작용에 사용됩니다. 멀티 스레딩의 장점은 컴퓨팅 성능을 향상시키는 것이지만 비동기의 장점은 UI 스레드를 차단하지 않는 것입니다. 멀티 스레딩 또는 비동기식을 선택하는 것은 작업의 특성에 따라 다릅니다. 계산 집약적 작업은 멀티 스레딩을 사용하고 외부 리소스와 상호 작용하고 UI 응답 성을 비동기식으로 유지 해야하는 작업을 사용합니다.

See all articles