PocketCsvReader 2.20.1

There is a newer version of this package available.
See the version list below for details.
dotnet add package PocketCsvReader --version 2.20.1                
NuGet\Install-Package PocketCsvReader -Version 2.20.1                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="PocketCsvReader" Version="2.20.1" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add PocketCsvReader --version 2.20.1                
#r "nuget: PocketCsvReader, 2.20.1"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install PocketCsvReader as a Cake Addin
#addin nuget:?package=PocketCsvReader&version=2.20.1

// Install PocketCsvReader as a Cake Tool
#tool nuget:?package=PocketCsvReader&version=2.20.1                

PocketCsvReader

Logo

PocketCsvReader is a highly efficient and lightweight library tailored for parsing delimited flat files like CSV and TSV. With a focus on simplicity and performance, it offers seamless file reading and supports versatile outputs, including DataTables, string arrays, strongly-typed object mapping and an IDataReader interface. Designed for projects requiring rapid data ingestion with minimal configuration, PocketCsvReader is a dependable solution for handling structured flat-file data effortlessly.

About | Install | Quick-start

About

Social media: website twitter badge

Releases: GitHub releases nuget GitHub Release Date licence badge

Dev. activity: GitHub last commit Still maintained GitHub commit activity

Continuous integration builds: Build status Tests CodeFactor codecov FOSSA Status

Status: stars badge Bugs badge Top language

Install

Replace <VersionNumber> with the desired version in each of the following solutions. If no version is specified, the latest version will be installed.

NuGet CLI

  1. Open a command prompt or terminal.

  2. Run the following command:

    nuget install PocketCsvReader -Version <VersionNumber>
    

Visual Studio Package Manager Console

  1. Open the Package Manager Console from Tools > NuGet Package Manager > Package Manager Console.

  2. Run the following command:

    Install-Package PocketCsvReader -Version <VersionNumber>
    

Dotnet-CLI

  1. Open a terminal or command prompt.

  2. Navigate to the directory of your project.

  3. Run the following command:

    dotnet add package PocketCsvReader --version <VersionNumber>
    

Quick-start

The CsvReader class is a flexible and efficient tool for reading and parsing CSV files or streams into various formats, such as DataTable, IDataReader, or strongly-typed objects. This documentation explains the basics of how to use the class, including common use cases and examples.

Features

  • Read CSV files or streams into a DataTable.
  • Access CSV data in a forward-only, read-only manner using IDataReader.
  • Map CSV records to strongly-typed objects.
  • Map CSV records to array of strings.
  • Customizable CSV parsing profiles for delimiters, quote handling, and more.
  • Supports encoding detection through the IEncodingDetector interface.

Initialization

You can create an instance of CsvReader with various configurations:

// Default configuration: comma-delimited, double quotes for escaping, 4 KB buffer size.
var csvReader = new CsvReader();

// Custom CSV profile (e.g., semicolon-delimited, double quotes for escaping).
var csvReaderWithProfile = new CsvReader(CsvProfile.SemiColumnDoubleQuote);

// Custom buffer size for large files.
var csvReaderWithBuffer = new CsvReader(bufferSize: 64 * 1024);

// Both custom profile and buffer size.
var csvReaderCustom = new CsvReader(CsvProfile.SemiColumnDoubleQuote, bufferSize: 16 * 1024);

Reading CSV Data

Reading Into a DataTable

The ToDataTable method reads CSV data and returns a DataTable containing all rows and fields.

DataTable dataTable = csvReader.ToDataTable("example.csv");

or to read from a stream,

using var stream = new FileStream("example.csv", FileMode.Open, FileAccess.Read);
DataTable dataTable = csvReader.ToDataTable(stream);

Accessing Data with IDataReader

The ToDataReader method provides a forward-only, read-only CsvDataReader implementing IDataReader for processing large files efficiently.

using var stream = new FileStream("example.csv", FileMode.Open, FileAccess.Read);
using var reader = csvReader.ToDataReader(stream);
while (reader.Read())
{
    Console.WriteLine(reader[0]); // Access the first column of the current row.
    Console.WriteLine(reader.GetDateTime(1)); // Access the second column of the current row as an object boxing a DateTime.
    Console.WriteLine(reader.GetFieldValue<DateOnly>(2); // Access the third column of the current row as DateOnly.
}

Reading as Arrays

using var stream = new FileStream("example.csv", FileMode.Open, FileAccess.Read);
foreach (var record in csvReader.ToArrayString(stream))
{
    Console.WriteLine(string.Join(", ", record));
}

Mapping Records to Strongly-Typed Objects

The To<T> method maps CSV records to objects of a specified type.

public class Person
{
    public string FirstName { get; set; }
    public string LastName { get; set; }
    public int Age { get; set; }
}

using var stream = new FileStream("example.csv", FileMode.Open, FileAccess.Read);
IEnumerable<Person> people = csvReader.To<Person>(stream);

foreach (var person in people)
{
    Console.WriteLine($"{person.FirstName} {person.LastName}, Age: {person.Age}");
}
Product Compatible and additional computed target framework versions.
.NET net8.0 is compatible.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 is compatible.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
  • net8.0

    • No dependencies.
  • net9.0

    • No dependencies.

NuGet packages (4)

Showing the top 4 NuGet packages that depend on PocketCsvReader:

Package Downloads
NBi.Framework

This package contains the NBi framework and references each dll to your project. This package is not intended to be directly used by end-users willing to create test-suites. Check the package NBi.VisualStudio, if you want to facilitate the usage of NBi from Visual Studio. NBi is a testing framework (add-on to NUnit) for Business Intelligence and Data Quality. It supports the Microsoft Data platform (SQL Server Database engine, SSIS, SSAS, SSRS) but also MySQL, PostgreSQL and other NoSQL solutions.

NBi.Framework.Tools

This package contains the NBi framework and references each dll to your project. This package is not intended to be directly used by end-users willing to create test-suites. Check the package NBi.VisualStudio, if you want to facilitate the usage of NBi from Visual Studio. NBi is a testing framework (add-on to NUnit) for Business Intelligence and Data Quality. It supports the Microsoft Data platform (SQL Server Database engine, SSIS, SSAS, SSRS) but also MySQL, PostgreSQL and other NoSQL solutions.

Didot.Core

Package Description

Packata.Core

Package Description

GitHub repositories (1)

Showing the top 1 popular GitHub repositories that depend on PocketCsvReader:

Repository Stars
Seddryck/NBi
NBi is a testing framework (add-on to NUnit) for Business Intelligence and Data Access. The main goal of this framework is to let users create tests with a declarative approach based on an Xml syntax. By the means of NBi, you don't need to develop C# or Java code to specify your tests! Either, you don't need Visual Studio or Eclipse to compile your test suite. Just create an Xml file and let the framework interpret it and play your tests. The framework is designed as an add-on of NUnit but with the possibility to port it easily to other testing frameworks.
Version Downloads Last updated
2.25.1 112 1/20/2025
2.25.0 106 1/19/2025
2.24.0 109 1/18/2025
2.23.0 171 1/12/2025
2.22.1 124 1/11/2025
2.22.0 64 1/11/2025
2.21.0 146 1/6/2025
2.20.2 76 1/6/2025
2.20.1 83 1/5/2025
2.20.0 89 1/5/2025
2.19.0 86 1/5/2025
2.18.1 80 1/5/2025
2.18.0 100 1/5/2025
2.17.0 107 1/4/2025
2.16.0 106 1/4/2025
2.15.0 95 1/4/2025
2.14.4 131 12/31/2024
2.14.2 117 12/30/2024
2.14.1 204 12/27/2024
2.14.0 138 12/27/2024
2.13.1 109 12/26/2024
2.13.0 221 12/22/2024
2.12.0 141 12/21/2024
2.11.1 156 12/17/2024
2.11.0 131 12/15/2024
2.10.0 86 12/14/2024
2.9.7 94 12/13/2024
2.9.4 196 11/30/2024
2.9.3 96 11/30/2024
2.9.2 88 11/30/2024
2.9.0 89 11/30/2024
2.8.2 110 11/24/2024
2.8.1 109 11/23/2024
2.8.0 200 11/17/2024
2.7.1 91 11/16/2024
2.7.0 87 11/16/2024
2.6.0 94 11/16/2024
2.5.2 98 11/16/2024
2.5.1 97 11/15/2024
2.5.0 99 11/15/2024
2.4.3 93 11/14/2024
2.4.2 96 11/12/2024
2.4.1 95 11/11/2024
2.4.0 102 11/10/2024
2.3.1 104 11/10/2024
2.3.0 113 11/9/2024
2.2.1 99 11/8/2024
2.2.0 104 11/7/2024
2.0.1 99 11/6/2024
2.0.0 102 7/31/2024
1.1.0-beta.1 429 3/26/2019
1.0.0 48,428 3/26/2019
0.1.0-beta.9 423 2/4/2019
0.1.0-beta.8 390 1/20/2019
0.1.0-beta.7 390 1/17/2019
0.1.0-beta.6 446 1/16/2019
0.1.0-beta.4 415 1/15/2019
0.1.0-beta.3 404 1/15/2019
0.1.0-beta.2 407 1/15/2019
0.1.0-beta.1 405 1/7/2019