DevToys.PocoCsv.Core
1.3.8
There is a newer version of this package available.
See the version list below for details.
See the version list below for details.
dotnet add package DevToys.PocoCsv.Core --version 1.3.8
NuGet\Install-Package DevToys.PocoCsv.Core -Version 1.3.8
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="DevToys.PocoCsv.Core" Version="1.3.8" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add DevToys.PocoCsv.Core --version 1.3.8
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: DevToys.PocoCsv.Core, 1.3.8"
#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 DevToys.PocoCsv.Core as a Cake Addin #addin nuget:?package=DevToys.PocoCsv.Core&version=1.3.8 // Install DevToys.PocoCsv.Core as a Cake Tool #tool nuget:?package=DevToys.PocoCsv.Core&version=1.3.8
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
DevToys.PocoCsv.Core
DevToys.PocoCsv.Core is a class library to read and write to Csv. It contains CsvStreamReader, CsvStreamWriter and Serialization classes CsvReader<T> and CsvWriter<T>.
- Read/write serialize/deserialize data to and from Csv fast.
- Use Linq to query large CSV files with CsvReader<T>.ReadAsEnumerable().
- Use CsvWriter<T>.Write() to write large data tables to Csv.
- Retrieve schema for a csv file with CsvUtils.GetCsvSchema() which can be used to create a poco object.
Three flavors for reading and writing CSV files:
- Stream
- <T> Serialize / Deserialize to T
- dynamic. Use dynamic to Read or Write CSV, this is slightly slower then <T>
CsvStreamReader
string file = "C:\Temp\data.csv";
using (CsvStreamReader _reader = new CsvStreamReader(file))
{
_reader.Separator = ',';
while (!_reader.EndOfCsvStream)
{
List<string> _values = _reader.ReadCsvLine().ToList();
}
}
CsvStreamWriter
string file = @"D:\Temp\test.csv";
using (CsvStreamWriter _writer = new CsvStreamWriter(file))
{
var _line = new string[] { "Row 1", "Row A,A", "Row 3", "Row B" };
_writer.WriteCsvLine(_line);
}
CsvReader<T>
public class Data
{
[Column(Index = 0)]
public string Column1 { get; set; }
[Column(Index = 1)]
public string Column2 { get; set; }
[Column(Index = 2)]
public string Column3 { get; set; }
[Column(Index = 5)]
public string Column5 { get; set; }
}
string file = @"D:\Temp\data.csv");
using (CsvReader<Data> _reader = new(file))
{
_reader.Open();
_reader.Separator = ','; // or use _reader.DetectSeparator();
var _data = Reader.ReadAsEnumerable().Where(p => p.Column1.Contains("16"));
var _materialized = _data.ToList();
}
Note: It's possible to use typed properties, but it is limited to basic conversions for the specified culture.
CsvWriter<T>
private IEnumerable<CsvSimple> LargeData()
{
for (int ii = 0; ii < 10000000; ii++)
{
CsvSimple _line = new()
{
AfBij = "bij",
Bedrag = "100",
Code = "test",
Datum = "20200203",
Mededelingen = $"test {ii}",
Rekening = "3434",
Tegenrekening = "3423424"
};
yield return _line;
}
}
string file = @"D:\largedata.csv";
using (CsvWriter<CsvSimple> _writer = new(file) { Separator = ',', Append = true })
{
_writer.Open();
_writer.Write(LargeData());
}
CsvReaderDynamic
string file = @"C:\Temp\data.csv";
using (CsvReaderDynamic _reader = new(file))
{
_reader.FirstRowIsHeader = true;
_reader.Open();
foreach (dynamic row in _reader.ReadAsEnumerable())
{
...
}
}
CsvWriterDynamic
string file = @"C:temp\data.csv");
using (CsvWriterDynamic _writer = new(file))
{
dynamic row = new ExpandoObject();
row.Id = 124;
row.Name = "Name";
List<dynamic> _data = new List<dynamic>();
_data.Add(row);
_writer.Write(_data);
}
Product | Versions 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 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. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
net6.0
- No dependencies.
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 |
---|---|---|
4.5.3 | 85 | 12/26/2024 |
4.5.2 | 82 | 12/18/2024 |
4.5.1 | 82 | 12/16/2024 |
4.5.0 | 81 | 12/16/2024 |
4.4.1 | 62 | 12/16/2024 |
4.4.0 | 101 | 12/14/2024 |
4.3.2 | 114 | 12/3/2024 |
4.3.1 | 90 | 11/22/2024 |
4.3.0 | 87 | 11/21/2024 |
4.2.5 | 88 | 11/20/2024 |
4.2.4 | 86 | 11/19/2024 |
4.2.3 | 104 | 11/13/2024 |
4.2.2 | 166 | 2/28/2024 |
4.2.1 | 122 | 2/24/2024 |
4.2.0 | 136 | 2/23/2024 |
4.1.2 | 109 | 2/22/2024 |
4.1.1 | 139 | 2/21/2024 |
4.1.0 | 132 | 2/21/2024 |
4.0.1 | 151 | 2/12/2024 |
4.0.0 | 137 | 2/12/2024 |
3.1.13 | 116 | 2/8/2024 |
3.1.12 | 156 | 2/7/2024 |
3.1.11 | 112 | 1/31/2024 |
3.1.10 | 123 | 1/19/2024 |
3.1.9 | 128 | 1/13/2024 |
3.1.8 | 128 | 1/12/2024 |
3.1.7 | 115 | 1/11/2024 |
3.1.5 | 139 | 1/8/2024 |
3.1.3 | 181 | 12/1/2023 |
3.1.2 | 141 | 12/1/2023 |
3.1.0 | 126 | 11/28/2023 |
3.0.7 | 215 | 8/27/2023 |
3.0.6 | 159 | 8/23/2023 |
3.0.5 | 167 | 8/23/2023 |
3.0.4 | 166 | 8/17/2023 |
3.0.3 | 182 | 8/15/2023 |
3.0.2 | 182 | 8/11/2023 |
3.0.1 | 201 | 8/11/2023 |
3.0.0 | 179 | 8/11/2023 |
2.0.7 | 226 | 8/9/2023 |
2.0.5 | 188 | 8/4/2023 |
2.0.4 | 187 | 8/3/2023 |
2.0.3 | 156 | 7/31/2023 |
2.0.2 | 183 | 7/28/2023 |
2.0.0 | 184 | 7/19/2023 |
1.7.53 | 223 | 4/14/2023 |
1.7.52 | 221 | 4/12/2023 |
1.7.51 | 208 | 4/7/2023 |
1.7.43 | 238 | 4/3/2023 |
1.7.42 | 220 | 4/3/2023 |
1.7.41 | 204 | 4/3/2023 |
1.7.5 | 209 | 4/7/2023 |
1.7.3 | 249 | 4/3/2023 |
1.7.2 | 237 | 4/3/2023 |
1.7.1 | 229 | 4/3/2023 |
1.7.0 | 235 | 4/1/2023 |
1.6.3 | 232 | 3/31/2023 |
1.6.2 | 235 | 3/29/2023 |
1.6.1 | 230 | 3/29/2023 |
1.6.0 | 224 | 3/27/2023 |
1.5.8 | 247 | 3/24/2023 |
1.5.7 | 217 | 3/22/2023 |
1.5.6 | 232 | 3/22/2023 |
1.5.5 | 241 | 3/21/2023 |
1.5.4 | 250 | 3/21/2023 |
1.5.1 | 239 | 3/20/2023 |
1.5.0 | 244 | 3/19/2023 |
1.4.5 | 240 | 3/18/2023 |
1.4.4 | 279 | 3/18/2023 |
1.4.3 | 235 | 3/18/2023 |
1.4.2 | 251 | 3/18/2023 |
1.4.1 | 217 | 3/18/2023 |
1.4.0 | 235 | 3/18/2023 |
1.3.92 | 246 | 3/18/2023 |
1.3.91 | 251 | 3/17/2023 |
1.3.9 | 238 | 3/17/2023 |
1.3.8 | 216 | 3/17/2023 |
1.3.7 | 245 | 3/17/2023 |
1.3.6 | 212 | 3/17/2023 |
1.3.5 | 227 | 3/17/2023 |
1.3.4 | 249 | 3/17/2023 |
1.3.3 | 238 | 3/16/2023 |
1.3.2 | 219 | 3/16/2023 |
1.3.1 | 246 | 3/16/2023 |
1.3.0 | 202 | 3/16/2023 |
1.2.0 | 240 | 3/14/2023 |
1.1.6 | 281 | 2/24/2023 |
1.1.5 | 326 | 2/16/2023 |
1.1.4 | 489 | 5/18/2022 |
1.1.3 | 725 | 1/27/2022 |
1.1.2 | 655 | 1/27/2022 |
1.1.1 | 706 | 1/14/2022 |
1.1.0 | 5,851 | 11/23/2021 |
1.0.5 | 402 | 5/11/2021 |
1.0.4 | 347 | 4/14/2021 |
1.0.3 | 388 | 4/12/2021 |
1.0.2 | 344 | 4/12/2021 |
1.0.1 | 325 | 4/7/2021 |
1.0.0 | 399 | 4/7/2021 |