検索
ホームページバックエンド開発C#.Net チュートリアルCSV ファイルに対する技術ソリューション用の .NET ライブラリ: CsvHelper 中国語ドキュメント

CsvHelper は、CSV ファイルの読み取りと書き込みのための .NET ライブラリです。 CsvHelper は、Visual Studio のパッケージ マネージャーを通じてダウンロードできます。自動マッピング定義: マッピング ファイルが指定されていない場合、デフォルトは自動マッピングであり、自動マッピングはクラスの属性に順番にマッピングされます。

GitHub アドレス

Read

すべてのレコードを読む

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();
}

マッピング

自動マッピング

マッピング ファイルが提供されていない場合、デフォルトの自動マッピングマッピングを行うと、自動マッピングがクラスの属性に順番にマッピングされます。属性がカスタム クラスの場合、このカスタム クラスの属性に従って引き続き入力されます。循環参照が発生すると、自動マッピングが停止します。

手動マッピング

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>();
    }
}
#が記録されます。 ##can オプションの型変換

デフォルトのコンバーターはほとんどの型変換を処理しますが、場合によっては小さな変更を加える必要がある場合があります。この時点では、オプションの型変換を使用してみることができます。

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.
        } );
    }
}

実行時マッピング

マッピングは実行時に作成できます。

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);

この記事はtangyikejunによって翻訳されました
構成

コメントを許可

// Default value
csv.Configuration.AllowComments = false;

自動マッピング

var generatedMap = csv.Configuration.AutoMap<MyClass>();

キャッシュ

TextReader または TextWriter での読み取りと書き込みのキャッシュ

// Default value
csv.Configuration.BufferSize = 2048;

Comment

コメントアウトされた行は読み込まれません

// Default value
csv.Configuration.Comment = &#39;#&#39;;

バイト数

現在の読み取り 何バイトが取得されましたか? CSV ファイルと一貫性を持たせるために、Configuration.Encoding を設定する必要があります。この設定は解析速度に影響します。

// Default value
csv.Configuration.CountBytes = false;

カルチャ情報

// Default value
csv.Configuration.CultureInfo = CultureInfo.CurrentCulture;

Separator

// Default value
csv.Configuration.Delimiter = ",";

列番号変更

オンにすると、列番号が変更された場合にCsvBadDataExceptionがスローされます

// 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 )];

属性バインディング タグ

カスタム クラスの属性の検索に使用されます

// Default value
csv.Configuration.PropertyBindingFlags = BindingFlags.Public | BindingFlags.Instance;

この記事は、tang yi ke junによって翻訳されました
Quote

区切り文字、括弧、または行末をエスケープするために使用するエスケープ文字を定義します。

// Default value
csv.Configuration.Quote = &#39;"&#39;;

すべてのフィールドの引用符

CSV に書き込むときにすべてのフィールドを引用符で囲むかどうか。 QuoteAllFields と QuoteNoFields を同時に true にすることはできません。

// Default value
csv.Configuration.QuoteAllFields = false;

すべてのフィールドは引用符で囲まれていません

QuoteAllFields と QuoteNoFields を同時に true にすることはできません。

// 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;

列名のトリミング

// Default value
csv.Configuration.TrimHeaders = false;

クラス マッピングのバインド解除

// Unregister single map.
csv.Configuration.UnregisterClassMap<MyClassMap>();
// Unregister all class maps.
csv.Configuration.UnregisterClassMap();

空のフィールドが例外をスローするかどうか

// Default value
csv.Configuration.WillThrowOnMissingField = true;

型変換

型変換は、CsvHelper が文字列を .NET 型に (またはその逆に) 変換する方法です。

その他

例外情報の表示

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;

DataReader および DataTable

DataReader オブジェクトが 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();
}

DataTable オブジェクトが書き込まれますCSV

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();
    }
}

CSV to DataTable

while( csv.Read() )
{
    var row = dt.NewRow();
    foreach( DataColumn column in dt.Columns )
    {
        row[column.ColumnName] = csv.GetField( column.DataType, column.ColumnName );
    }
    dt.Rows.Add( row );
}

関連記事:


.net CsvHelper 2.0

jQuery EasyUI API 中国語ドキュメント - Documentation Documentation_jquery

関連ビデオ:

Ruby 中国語ドキュメント

以上がCSV ファイルに対する技術ソリューション用の .NET ライブラリ: CsvHelper 中国語ドキュメントの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
C#.NETエコシステム:フレームワーク、ライブラリ、およびツールC#.NETエコシステム:フレームワーク、ライブラリ、およびツールApr 24, 2025 am 12:02 AM

C#.NETエコシステムは、開発者がアプリケーションを効率的に構築できるようにするための豊富なフレームワークとライブラリを提供します。 1.ASP.NETCOREは、高性能Webアプリケーションの構築に使用されます。2.EntityFrameWorkCoreは、データベース操作に使用されます。これらのツールの使用とベストプラクティスを理解することにより、開発者はアプリケーションの品質とパフォーマンスを向上させることができます。

azure/awsへのc#.netアプリケーションの展開:ステップバイステップガイドazure/awsへのc#.netアプリケーションの展開:ステップバイステップガイドApr 23, 2025 am 12:06 AM

c#.netアプリをAzureまたはAWSに展開する方法は?答えは、AzureAppServiceとAwselasticBeanStalkを使用することです。 1。Azureでは、AzureAppServiceとAzurePipelinesを使用して展開を自動化します。 2。AWSでは、Amazon ElasticBeanstalkとAwslambdaを使用して、展開とサーバーレス計算を実装します。

C#.NET:強力なプログラミング言語の紹介C#.NET:強力なプログラミング言語の紹介Apr 22, 2025 am 12:04 AM

C#と.NETの組み合わせにより、開発者に強力なプログラミング環境を提供します。 1)C#は、多型と非同期プログラミングをサポートします。2).NETは、クロスプラットフォーム機能と同時処理メカニズムを提供し、デスクトップ、Web、モバイルアプリケーション開発で広く使用されています。

.NETフレームワーク対C#:用語のデコード.NETフレームワーク対C#:用語のデコードApr 21, 2025 am 12:05 AM

.NetFrameworkはソフトウェアフレームワークであり、C#はプログラミング言語です。 1..netframeworkは、デスクトップ、Web、モバイルアプリケーションの開発をサポートするライブラリとサービスを提供します。 2.C#は.NetFrameWork用に設計されており、最新のプログラミング機能をサポートしています。 3..NetFrameworkはCLRを介してコード実行を管理し、C#コードはILにコンパイルされ、CLRによって実行されます。 4. .NetFrameWorkを使用してアプリケーションをすばやく開発し、C#はLINQなどの高度な関数を提供します。 5.一般的なエラーには、タイプ変換と非同期プログラミングデッドロックが含まれます。 VisualStudioツールは、デバッグに必要です。

C#.NETの分解:初心者の概要C#.NETの分解:初心者の概要Apr 20, 2025 am 12:11 AM

C#は、Microsoftが開発した最新のオブジェクト指向プログラミング言語であり、.NETはMicrosoftが提供する開発フレームワークです。 C#は、CのパフォーマンスとJavaのシンプルさを組み合わせており、さまざまなアプリケーションの構築に適しています。 .NETフレームワークは、複数の言語をサポートし、ガベージコレクションメカニズムを提供し、メモリ管理を簡素化します。

C#と.NETランタイム:それらがどのように連携するかC#と.NETランタイム:それらがどのように連携するかApr 19, 2025 am 12:04 AM

C#と.NETランタイムは密接に連携して、開発者に効率的で強力なプラットフォームの開発機能に力を与えます。 1)C#は、.NETフレームワークとシームレスに統合するように設計されたタイプセーフおよびオブジェクト指向のプログラミング言語です。 2).NETランタイムは、C#コードの実行を管理し、ガベージコレクション、タイプの安全性、その他のサービスを提供し、効率的でクロスプラットフォームの操作を保証します。

C#.NET開発:始めるための初心者向けガイドC#.NET開発:始めるための初心者向けガイドApr 18, 2025 am 12:17 AM

C#.NET開発を開始するには、次のことが必要です。1。C#の基本的な知識と.NETフレームワークのコア概念を理解する。 2。変数、データ型、制御構造、関数、クラスの基本概念をマスターします。 3。LINQや非同期プログラミングなど、C#の高度な機能を学習します。 4.一般的なエラーのためのデバッグテクニックとパフォーマンス最適化方法に精通してください。これらの手順を使用すると、C#.NETの世界に徐々に浸透し、効率的なアプリケーションを書き込むことができます。

C#と.NET:2つの関係を理解し​​ますC#と.NET:2つの関係を理解し​​ますApr 17, 2025 am 12:07 AM

C#と.NETの関係は切り離せませんが、同じものではありません。 C#はプログラミング言語であり、.NETは開発プ​​ラットフォームです。 C#は、コードの書き込み、.NETの中間言語(IL)にコンパイルされ、.NET Runtime(CLR)によって実行されるために使用されます。

See all articles

ホット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 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

mPDF

mPDF

mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

Dreamweaver Mac版

Dreamweaver Mac版

ビジュアル Web 開発ツール

PhpStorm Mac バージョン

PhpStorm Mac バージョン

最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

MantisBT

MantisBT

Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。