Sylvan.Data.Csv
1.4.2
Prefix Reserved
dotnet add package Sylvan.Data.Csv --version 1.4.2
NuGet\Install-Package Sylvan.Data.Csv -Version 1.4.2
<PackageReference Include="Sylvan.Data.Csv" Version="1.4.2" />
<PackageVersion Include="Sylvan.Data.Csv" Version="1.4.2" />
<PackageReference Include="Sylvan.Data.Csv" />
paket add Sylvan.Data.Csv --version 1.4.2
#r "nuget: Sylvan.Data.Csv, 1.4.2"
#:package Sylvan.Data.Csv@1.4.2
#addin nuget:?package=Sylvan.Data.Csv&version=1.4.2
#tool nuget:?package=Sylvan.Data.Csv&version=1.4.2
Sylvan.Data.Csv
A cross-platform .NET library for reading and writing CSV data files.
The CsvDataReader
provides readonly, row by row, forward-only access to the data.
Exposes a familiar API via DbDataReader
, which is ideal for accessing rectangular, tabular data sets.
Sylvan.Data.Csv is currently the fastest library for reading CSV data
in the .NET ecosystem.
Features
- Auto detect delimiters.
- Supports asynchronous IO.
- Strongly-typed accessors that avoid allocations.
- Supported types includes all standard .NET primitive types,
DateOnly
andTimeOnly
on .NET 6, - Binary data encoded with either base64 or hexadecimal.
- Supported types includes all standard .NET primitive types,
- Schema information to support database bulk-load operations.
Usage Examples
Basic
using Sylvan.Data.Csv;
// CsvDataReader derives from System.Data.DbDataReader
using CsvDataReader dr = CsvDataReader.Create("data.csv");
// iterate over the rows in the file.
while(dr.Read())
{
// iterate fields in row.
for(int i = 0; i < dr.FieldCount; i++)
{
var value = dr.GetString(i);
}
// Can use other strongly-typed accessors
// bool flag = edr.GetBoolean(0);
// DateTime date = edr.GetDateTime(1);
// decimal amt = edr.GetDecimal(2);
}
Bind CSV data to objects using Sylvan.Data.
using Sylvan.Data;
using Sylvan.Data.Csv;
using System.Linq;
using var dr = CsvDataReader.Create("data.csv");
IEnumerable<Record> records = dr.GetRecords<Record>();
Record[] allRecords = records.ToArray();
class Record {
public int Id { get; set; }
public string Name { get; set; }
public DateTime Date { get; set; }
public decimal Amount { get; set; }
}
Convert Excel data to CSV using Sylvan.Data and Sylvan.Data.Excel
using Sylvan.Data;
using Sylvan.Data.Csv;
using Sylvan.Data.Excel;
using System.Data.Common;
// create reader for excel data file
ExcelDataReader edr = ExcelDataReader.Create("example.xlsx");
// (optional) create data reader which allows variable-length rows
DbDataReader reader = edr.AsVariableField(edr => edr.RowFieldCount);
// create CSV writer to standard out
var csvWriter = CsvDataWriter.Create(Console.Out);
// write excel data as csv
csvWriter.Write(reader);
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. 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 was computed. 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 was computed. 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. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 is compatible. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- No dependencies.
-
.NETStandard 2.1
- No dependencies.
-
net6.0
- No dependencies.
NuGet packages (9)
Showing the top 5 NuGet packages that depend on Sylvan.Data.Csv:
Package | Downloads |
---|---|
GreatUtilities.Infrastructure
Essencial tools to agile development. |
|
DbNetSuiteCore
Interactive data-driven UI components for ASP.Net Core Razor pages, MVC views and Blazor SSR. Support for MSSQL, MySql, PostgreSql, Oracle, MongoDB, SQLite, JSON, Excel, CSV and the file system |
|
LuminaSupplemental.Excel
Supplemental data for lumina and dalamud plugins. |
|
cai.reporting
Provides helpers to generate report using FastReport |
|
Sylvan.AspNetCore.Mvc.Csv
Package Description |
GitHub repositories (4)
Showing the top 4 popular GitHub repositories that depend on Sylvan.Data.Csv:
Repository | Stars |
---|---|
LykosAI/StabilityMatrix
Multi-Platform Package Manager for Stable Diffusion
|
|
nietras/Sep
World's Fastest .NET CSV Parser. Modern, minimal, fast, zero allocation, reading and writing of separated values (`csv`, `tsv` etc.). Cross-platform, trimmable and AOT/NativeAOT compatible.
|
|
JasonBock/Rocks
A mocking library based on the Compiler APIs (Roslyn + Mocks)
|
|
MarkPflug/Sylvan.Data.Excel
The fastest .NET library for reading Excel data files.
|
Version | Downloads | Last Updated | |
---|---|---|---|
1.4.2 | 77,468 | 4/23/2025 | |
1.4.1 | 70,977 | 2/27/2025 | |
1.4.0 | 46,257 | 2/5/2025 | |
1.3.9 | 282,355 | 7/2/2024 | |
1.3.8 | 125,982 | 4/23/2024 | |
1.3.7 | 126,520 | 2/10/2024 | |
1.3.6 | 2,571 | 2/6/2024 | |
1.3.6-b0001 | 111 | 2/5/2024 | |
1.3.5 | 127,138 | 11/3/2023 | |
1.3.4 | 1,758 | 11/2/2023 | |
1.3.3 | 154,598 | 7/17/2023 | |
1.3.2 | 45,584 | 6/6/2023 | |
1.3.2-b0001 | 225 | 5/30/2023 | |
1.3.1 | 19,348 | 5/7/2023 | |
1.3.0 | 25,681 | 4/25/2023 | |
1.2.7 | 137,251 | 2/15/2023 | |
1.2.6 | 1,617 | 2/13/2023 | |
1.2.6-b0003 | 374 | 2/10/2023 | |
1.2.6-b0002 | 288 | 2/8/2023 | |
1.2.6-b0001 | 207 | 2/7/2023 | |
1.2.5 | 10,046 | 1/16/2023 | |
1.2.4 | 258,039 | 10/25/2022 | |
1.2.3 | 1,684 | 10/21/2022 | |
1.2.2 | 38,283 | 9/12/2022 | |
1.2.1 | 1,677 | 9/8/2022 | |
1.2.0 | 22,728 | 8/28/2022 | |
1.1.16 | 366,735 | 6/14/2022 | |
1.1.15 | 2,064 | 6/2/2022 | |
1.1.14 | 1,719 | 6/1/2022 | |
1.1.13 | 146,551 | 3/31/2022 | |
1.1.12 | 38,245 | 2/18/2022 | |
1.1.11 | 34,049 | 1/5/2022 | |
1.1.10 | 5,602 | 12/9/2021 | |
1.1.9 | 13,967 | 10/23/2021 | |
1.1.8 | 21,153 | 9/8/2021 | |
1.1.7 | 3,857 | 8/14/2021 | |
1.1.6 | 1,524 | 8/13/2021 | |
1.1.5 | 1,588 | 8/8/2021 | |
1.1.4 | 1,908 | 8/5/2021 | |
1.1.3 | 5,104 | 7/23/2021 | |
1.1.2 | 1,575 | 7/19/2021 | |
1.1.1 | 1,702 | 7/15/2021 | |
1.1.0 | 1,677 | 7/14/2021 | |
1.0.3 | 3,385 | 5/21/2021 | |
1.0.2 | 1,564 | 5/15/2021 | |
1.0.1 | 2,378 | 5/4/2021 | |
1.0.0 | 1,846 | 4/5/2021 | |
0.10.1 | 1,587 | 3/27/2021 | |
0.10.0 | 1,856 | 3/15/2021 | |
0.9.2 | 1,718 | 1/31/2021 | |
0.9.1 | 1,590 | 1/25/2021 | |
0.9.0 | 1,779 | 1/9/2021 | |
0.8.3 | 1,538 | 1/6/2021 | |
0.8.2 | 1,698 | 1/4/2021 | |
0.8.1 | 1,545 | 1/3/2021 | |
0.8.0 | 1,689 | 11/30/2020 | |
0.7.4 | 1,604 | 9/28/2020 | |
0.7.2 | 5,017 | 9/11/2020 | |
0.7.0 | 1,701 | 9/10/2020 | |
0.6.3 | 1,683 | 8/10/2020 | |
0.6.2 | 1,684 | 8/7/2020 | |
0.6.1 | 1,626 | 8/4/2020 | |
0.6.0 | 1,684 | 8/3/2020 | |
0.5.0 | 1,709 | 6/30/2020 | |
0.4.5 | 1,683 | 6/25/2020 | |
0.4.4 | 1,680 | 6/25/2020 | |
0.4.3 | 1,931 | 6/10/2020 | |
0.4.2 | 1,805 | 5/29/2020 | |
0.4.1 | 1,676 | 5/2/2020 | |
0.4.0 | 1,708 | 4/29/2020 | |
0.3.4 | 1,734 | 4/21/2020 | |
0.3.3 | 1,707 | 4/16/2020 | |
0.3.2 | 1,610 | 4/15/2020 | |
0.3.1 | 1,671 | 4/13/2020 | |
0.3.0 | 1,675 | 4/10/2020 | |
0.2.1 | 1,789 | 4/7/2020 | |
0.2.0 | 1,664 | 4/7/2020 | |
0.1.2 | 1,696 | 4/7/2020 | |
0.1.1 | 1,653 | 4/6/2020 | |
0.1.0 | 3,463 | 4/4/2020 |