Ministry.Csv 2.0.0

dotnet add package Ministry.Csv --version 2.0.0                
NuGet\Install-Package Ministry.Csv -Version 2.0.0                
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="Ministry.Csv" Version="2.0.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Ministry.Csv --version 2.0.0                
#r "nuget: Ministry.Csv, 2.0.0"                
#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 Ministry.Csv as a Cake Addin
#addin nuget:?package=Ministry.Csv&version=2.0.0

// Install Ministry.Csv as a Cake Tool
#tool nuget:?package=Ministry.Csv&version=2.0.0                

Introduction

This project provides a Generator for building CSV objects from files and vice versa. The CSV object structure is very simple and string orientated, reflecting the nature of the CSV file itself, with Rows and Cells modelled as their own classes. There is no strong typing involved.

The CSV Definition

The CsvDefinition class is a pure representation of CSV content. It has two properties providing lists of the Headers and a list of Rows. A Row is a CsvRow object that consists of one or more CsvCell objects. The class has several methods to enable you to manually add individual or multiple headers and rows to the definition. The syntax is fluent so you can build a definition in a single block. For example...

var myCsv = new CsvDefinition()
   .AddHeaders("Name", "Age", "Grade")
   .AddRow("Bobby", 12, "C+")
   .AddRow("Sam", 12, "A")
   .AddRow("Lily", 11, "B");

The CSV Generator

The CSV Generator class is the heart of the library. It is a static class that manages translating CSV content into an object and vice versa.

  • From Bytes(byte[] source) - Takes a byte array (say, from a file upload) and converts it into a CsvDefinition object.
  • FromString(string source) - Takes a string representing a whole CSV file content and converts it into a CsvDefinition object.
  • GenerateString(CsvDefinition definition) - Takes a CsvDefinition object and converts it to string content. Can be used as an extension method to the CsvDefinition object.
  • GenerateFile(CsvDefinition definition, string path) - Takes a CsvDefinition object and writes a file to the specified path. Can be used as an extension method to the CsvDefinition object.
  • GenerateBytes(CsvDefinition definition) - Takes a CsvDefinition object and converts it into a byte array. Can be used as an extension method to the CsvDefinition object.

These can be used to create a CSV file from code like this...

var myCsv = new CsvDefinition()
   .AddHeaders("Name", "Age", "Grade")
   .AddRow("Bobby", 12, "C+")
   .AddRow("Sam", 12, "A")
   .AddRow("Lily", 11, "B")
   .GenerateFile("C:\mycsv.csv");

or in reverse...

var myCsv = CsvGenerator.FromBytes(File.ReadAllBytes("C:\mycsv.csv"));

Upgrading v2.x

v2 no longer supports .net Standard and .net Framework.

The Ministry of Technology Open Source Products

Welcome to The Ministry of Technology open source products. All open source Ministry of Technology products are distributed under the MIT License for maximum re-usability. Our other open source repositories can be found here...

Where can I get it?

You can download the package for this project from any of the following package managers...

Contribution guidelines

If you would like to contribute to the project, please contact me.

Who do I talk to?

  • Keith Jackson - temporal-net@live.co.uk
Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
2.0.0 196 12/29/2023
1.0.3 1,478 6/11/2018
1.0.2 990 6/11/2018
1.0.1 929 5/9/2018
1.0.0 958 3/21/2018