CsvLINQPadDriver 8.12.0
dotnet add package CsvLINQPadDriver --version 8.12.0
NuGet\Install-Package CsvLINQPadDriver -Version 8.12.0
<PackageReference Include="CsvLINQPadDriver" Version="8.12.0" />
paket add CsvLINQPadDriver --version 8.12.0
#r "nuget: CsvLINQPadDriver, 8.12.0"
// Install CsvLINQPadDriver as a Cake Addin #addin nuget:?package=CsvLINQPadDriver&version=8.12.0 // Install CsvLINQPadDriver as a Cake Tool #tool nuget:?package=CsvLINQPadDriver&version=8.12.0
CsvLINQPadDriver for LINQPad 8/7/6/5
Table of Contents
- Description
- Website
- Download
- Example
- Prerequisites
- Installation
- Usage
- Configuration Options
- Relations Detection
- Performance
- Data Types
- Generated Data Object
- Known Issues
- Troubleshooting
- Authors
- Credits
- License
Description
CsvLINQPadDriver is LINQPad 8/7/6/5 data context dynamic driver for querying CSV files.
- You can query data in CSV files with LINQ, just like it would be regular database. No need to write custom data model, mappings, etc.
- Driver automatically generates new data types for every CSV file with corresponding properties and mappings for all the columns. Every column is a
string
, no data type detection is provided. - Based on column and file names, possible relations between CSV tables are detected and generated.
- Single class generation allows to join similar files and query over them. Might not work well for files with relations.
Website
Download
Latest CsvLINQPadDriver.*.lpx6/CsvLINQPadDriver.*.lpx for LINQPad 8/7/6/5 manual installation.
Example
Let's have 2 CSV files:
Authors.csv
Id,Name
1,Author 1
2,Author 2
3,Author 3
Books.csv
Id,Title,AuthorId
11,Author 1 Book 1,1
12,Author 1 Book 2,1
21,Author 2 Book 1,2
CsvLINQPadDriver will generate data context similar to (simplified):
public class CsvDataContext
{
public CsvTableBase<RAuthor> Authors { get; private set; }
public CsvTableBase<RBook> Books { get; private set; }
}
// record/class for LINQPad 8/7/6, class for LINQPad 5.
public sealed record RAuthor
{
public string? Id { get; set; }
public string? Name { get; set; }
public IEnumerable<RBook>? Books { get; set; }
}
public sealed record RBook
{
public string? Id { get; set; }
public string? Title { get; set; }
public string? AuthorId { get; set; }
public IEnumerable<RAuthor>? Authors { get; set; }
}
And you can query data with LINQ like:
from book in Books
join author in Authors on book.AuthorId equals author.Id
select new { author.Name, book.Title }
Prerequisites
- LINQPad 8: .NET 8/.NET 7/.NET 6
- LINQPad 7: .NET 7/.NET 6/.NET 5/.NET Core 3.1
- LINQPad 6: .NET 5/.NET Core 3.1
- LINQPad 5: .NET Framework 4.7.1
Installation
LINQPad 8/7/6
NuGet
- Open LINQPad 8/7/6.
- Click
Add connection
link. - Click button
View more drivers...
- Click radio button
Show all drivers
and typeCsvLINQPadDriver
- Install.
Manual
Get latest CsvLINQPadDriver.*.lpx6 file.
- Open LINQPad 8/7/6.
- Click
Add connection
link. - Click button
View more drivers...
- Click button
Install driver from .LPX6 file...
and select downloadedlpx6
file.
LINQPad 5
Get latest CsvLINQPadDriver.*.lpx file.
- Open LINQPad 5.
- Click
Add connection
link. - Click button
View more drivers...
- Click button
Browse...
and select downloadedlpx
file.
Usage
CSV files connection can be added to LINQPad 8/7/6/5 the same way as any other connection.
- Click
Add connection
- Select
CSV Context Driver
and clickNext
- Enter CSV file names or Drag&Drop (
Ctrl
adds files) from Explorer. Optionally configure other options. - Query your data.
Configuration Options
CSV Files
- CSV files: list of CSV files and folders. Can be added via files/folder dialogs, context menu, hotkeys, by typing one file/folder per line or by Drag&drop (
Ctrl
adds files,Alt
toggles*
and**
masks). Wildcards?
and*
are supported;**.csv
searches in folder and its sub-folders.c:\Books\Books?.csv
:Books.csv
,Books1.csv
, etc. files in folderc:\Books
c:\Books\*.csv
: all*.csv
files in folderc:\Books
c:\Books\**.csv
: all*.csv
files in folderc:\Books
and its sub-folders.
- Order files by: files sort order. Affects similar files order.
- Fallback encoding: encoding to use if file encoding could not be detected.
UTF-8
is used by default. - Auto-detect file encodings: try to detect file encodings.
- Validate file paths: checks if file paths are valid.
- Ignore files with invalid format: files with content which does not resemble CSV will be ignored.
- Do not lock files being read: allow other processes to modify files being read.
[!NOTE] Driver does not track files changes.
Format
- Separator: characters used to separate columns in files. Can be
,
,\t
, etc. Auto-detected if empty. - Use CsvHelper library separator auto-detection: use CsvHelper library separator auto-detection instead of internal one.
- Ignore bad data: ignore malformed files.
- Ignore blank lines: do not process blank lines.
- Parsing mode:
- Use RFC 4180 format: if a field contains a
Separator
orNewLine
character, it is wrapped inQuote
characters. If quoted field contains aQuote
character, it is preceded byEscape
character. - Use escapes: if a field contains a
Separator
,NewLine
orEscape
character, it should be preceded byEscape
character. - Do not use quotes or escapes: ignore quoting and escape characters. This means a field cannot contain a
Separator
,Quote
orNewLine
characters as they cannot be escaped.
- Use RFC 4180 format: if a field contains a
- Escape: the character used to escape characters.
"
if empty. - Quote: the character used to quote fields.
"
if empty. - Skip leading rows: allow to skip the specified number of leading rows.
- Trim spaces: allow to trim spaces around fields and/or inside quotes around fields.
- Allow comments: allow single-line comments - lines starting with
#
(which is used by default) will be ignored. - Header detection: detect or add header with specific column fallback name format if header could not be detected.
- Header detection approach: specify whether header is present or not, or how to detect it by symbols it consists of.
- Header column fallback name format: define generated columns names if there is no header.
Memory
- Cache data in memory:
- if checked: parsed rows are cached in memory. Cache survives multiple query runs, even when query is changed. Cache is cleared as soon as LINQPad clears query data. May significantly increase memory usage.
- if unchecked: disable cache. Multiple enumerations of file content results in multiple reads and parsing of file. Can be significantly slower for complex queries. Significantly reduces memory usage. Useful when reading very large files.
- Intern strings: intern strings. May significantly reduce memory consumption when CSV contains repeatable values; may significantly increase memory usage otherwise.
- Use generation string comparison: compare interned strings using generation string comparison.
Ordinal
is used by default.
- Use generation string comparison: compare interned strings using generation string comparison.
Generation
- Use record type: generate records instead of classes (LINQPad 8/7/6 only).
- Generate single type for similar files: single type will be generated for similar files which allows to join similar files and query over them. Relations support is limited.
- Also show similar files non-grouped: show similar files non-grouped in addition to similar files groups.
- Rename table:
- if checked: the table name will be renamed according to the selected table name format.
- if unchecked: the table name is the file name.
- String comparison: string comparison for
Equals
andGetHashCode
methods.
Relations
- Detect relations: driver will try to detect and generate relations between files.
- Hide relations from
Dump()
: LINQPad will not show relations content whenDump()
ed. This prevents loading too many data.
- Hide relations from
Misc
- Debug info: show additional driver debug info, e.g. generated data context source, and enable logging.
- Remember this connection: connection will be available on next run.
- Contains production data: files contain production data.
Relations Detection
There is no definition of relations between CSV files, but we can guess some relations from files and columns names.
Relations between fileName.columnName
are detected in cases similar to following examples:
Books.AuthorId <-> Authors.Id
Books.AuthorsId <-> Authors.Id
Books.AuthorId <-> Authors.AuthorId
Books.Id <-> Authors.BookId
Performance
When executing LINQ query for CSV connection:
- Only files used in query are loaded from disk.
- As soon as any record from file is accessed, whole file is loaded into memory.
- Relations are lazily evaluated and retrieved using cached lookup tables.
Don't expect performance comparable with SQL server. But for reasonably sized CSV files there should not be any problem.
Data Types
Everything is string
. Because there is no data type info in CSV files, this is the best we can do - see conversion extension methods.
Generated Data Object
Generated data object is sealed mutable class or record (LINQPad 8/7/6 only). You can create record's shallow copy using with expression.
Methods
string? ToString();
bool Equals(T? obj);
bool Equals(object? obj);
static bool operator == (T? obj1, T? obj2);
static bool operator != (T? obj1, T? obj2);
int GetHashCode();
string? this[int index] { get; set; }
string? this[string index] { get; set; }
ToString
string? ToString();
Formats object the way PowerShell Format-List does.
[!NOTE] Relations are not participated.
GetHashCode
int GetHashCode();
Returns object hash code.
[!IMPORTANT]
- Generated data object is mutable.
- Hash code is not cached and recalculated each time method is called.
- Each time driver is reloaded string hash codes will be different.
[!NOTE] Depends on string comparison driver setting. Relations are not participated.
Equals
bool Equals(T? obj);
bool Equals(object? obj);
[!NOTE] Depends on string comparison driver setting. Relations are not participated.
Overloaded Operators
static bool operator == (T? obj1, T? obj2);
static bool operator != (T? obj1, T? obj2);
[!NOTE] Depends on string comparison driver setting. Relations are not participated.
Indexers
string? this[int index] { get; set; }
string? this[string index] { get; set; }
See properties access below.
[!NOTE] Relations are not participated.
Properties Access
- Generated data objects are mutable, however saving changes is not supported.
- Generated data object properties can be accessed either by case-sensitive name or via indexer.
- Index can be integer (zero-based property index) or string (case-sensitive property name). If there is no index
IndexOutOfRangeException
will be thrown. - Relations cannot be accessed via indexers.
var author = Authors.First();
// Property (preferable).
var name = author.Name;
author.Name = name;
// Integer indexer.
var name = author[0];
author[0] = name;
// String indexer.
var name = author["Name"];
author["Name"] = name;
Property index can be found by hovering over property name at the connection pane or by using code below:
Authors.First()
.GetType().GetProperties()
.Where(p => !p.GetCustomAttributes().Any())
.Select((p, i) => new { Index = i, p.Name })
Extension Methods
- Driver provides extension methods for converting
string
(andReadOnlySpan<char>
for .NET Core/.NET) toT?
CultureInfo.InvariantCulture
is used forprovider
by default.null
is returned fornull
or empty input.CsvLINQPadDriver.ConvertException
is thrown for non-Safe
methods.- These methods are much more (~3-5 times) slower than .NET methods due to road-trip to driver.
public static class Styles
{
public const NumberStyles Integer =
NumberStyles.Integer |
NumberStyles.AllowThousands;
public const NumberStyles Float =
NumberStyles.Float |
NumberStyles.AllowThousands;
public const NumberStyles Decimal =
NumberStyles.Number;
public const DateTimeStyles DateTimeOffset =
DateTimeStyles.None;
public const DateTimeStyles DateTime =
DateTimeStyles.None;
public const DateTimeStyles UtcDateTime =
DateTimeStyles.AdjustToUniversal |
DateTimeStyles.AssumeUniversal;
public const TimeSpanStyles TimeSpan =
TimeSpanStyles.None;
// .NET 6+
public const DateTimeStyles DateOnly =
DateTimeStyles.None;
// .NET 6+
public const DateTimeStyles TimeOnly =
DateTimeStyles.None;
}
// Bool
bool? ToBool(
NumberStyles style = Styles.Integer,
IFormatProvider? provider = null);
bool? ToBoolSafe(
NumberStyles style = Styles.Integer,
IFormatProvider? provider = null);
// SByte
sbyte? ToSByte(
NumberStyles style = Styles.Integer,
IFormatProvider? provider = null);
sbyte? ToSByteSafe(
NumberStyles style = Styles.Integer,
IFormatProvider? provider = null);
// Byte
byte? ToByte(
NumberStyles style = Styles.Integer,
IFormatProvider? provider = null);
byte? ToByteSafe(
NumberStyles style = Styles.Integer,
IFormatProvider? provider = null);
// Short
short? ToShort(
NumberStyles style = Styles.Integer,
IFormatProvider? provider = null);
short? ToShortSafe(
NumberStyles style = Styles.Integer,
IFormatProvider? provider = null);
// UShort
ushort? ToUShort(
NumberStyles style = Styles.Integer,
IFormatProvider? provider = null);
ushort? ToUShortSafe(
NumberStyles style = Styles.Integer,
IFormatProvider? provider = null);
// Int
int? ToInt(
NumberStyles style = Styles.Integer,
IFormatProvider? provider = null);
int? ToIntSafe(
NumberStyles style = Styles.Integer,
IFormatProvider? provider = null);
// UInt
uint? ToUInt(
NumberStyles style = Styles.Integer,
IFormatProvider? provider = null);
uint? ToUIntSafe(
NumberStyles style = Styles.Integer,
IFormatProvider? provider = null);
// Long
long? ToLong(
NumberStyles style = Styles.Integer,
IFormatProvider? provider = null);
long? ToLongSafe(
NumberStyles style = Styles.Integer,
IFormatProvider? provider = null);
// ULong
ulong? ToULong(
NumberStyles style = Styles.Integer,
IFormatProvider? provider = null);
ulong? ToULongSafe(
NumberStyles style = Styles.Integer,
IFormatProvider? provider = null);
// NInt: .NET 5+
nint? ToNInt(
NumberStyles style = Styles.Integer,
IFormatProvider? provider = null);
nint? ToNIntSafe(
NumberStyles style = Styles.Integer,
IFormatProvider? provider = null);
// NUInt: .NET 5+
nuint? ToNUInt(
NumberStyles style = Styles.Integer,
IFormatProvider? provider = null);
nuint? ToNUIntSafe(
NumberStyles style = Styles.Integer,
IFormatProvider? provider = null);
// BigInteger
BigInteger? ToBigInteger(
NumberStyles style = Styles.Integer,
IFormatProvider? provider = null);
BigInteger? ToBigIntegerSafe(
NumberStyles style = Styles.Integer,
IFormatProvider? provider = null);
// Float
float? ToFloat(
NumberStyles style = Styles.Float,
IFormatProvider? provider = null);
float? ToFloatSafe(
NumberStyles style = Styles.Float,
IFormatProvider? provider = null);
// Double
double? ToDouble(
NumberStyles style = Styles.Float,
IFormatProvider? provider = null);
double? ToDoubleSafe(
NumberStyles style = Styles.Float,
IFormatProvider? provider = null);
// Decimal
decimal? ToDecimal(
NumberStyles style = Styles.Decimal,
IFormatProvider? provider = null);
decimal? ToDecimalSafe(
NumberStyles style = Styles.Decimal,
IFormatProvider? provider = null);
// Half: .NET 5+
Half? ToHalf(
NumberStyles style = Styles.Float,
IFormatProvider? provider = null);
Half? ToHalfSafe(
NumberStyles style = Styles.Float,
IFormatProvider? provider = null);
// Int128: .NET 7+
static Int128? ToInt128(
NumberStyles style = Styles.Integer,
IFormatProvider? provider = null);
static Int128? ToInt128Safe(
NumberStyles style = Styles.Integer,
IFormatProvider? provider = null);
// UInt128: .NET 7+
static UInt128? ToUInt128(
NumberStyles style = Styles.Integer,
IFormatProvider? provider = null);
static UInt128? ToUInt128Safe(
NumberStyles style = Styles.Integer,
IFormatProvider? provider = null);
// Complex
Complex? ToComplex(
NumberStyles style = Styles.Float,
IFormatProvider? provider = null);
Complex? ToComplexSafe(
NumberStyles style = Styles.Float,
IFormatProvider? provider = null);
// Guid
Guid? ToGuid();
Guid? ToGuidSafe();
Guid? ToGuid(string format);
Guid? ToGuidSafe(string format);
Guid? ToGuid(ReadOnlySpan<char> format);
Guid? ToGuidSafe(ReadOnlySpan<char> format);
Guid? ToGuid(string[] formats);
Guid? ToGuidSafe(string[] formats);
// DateTime
DateTime? ToDateTime(
DateTimeStyles style = Styles.DateTime,
IFormatProvider? provider = null);
DateTime? ToDateTimeSafe(
DateTimeStyles style = Styles.DateTime,
IFormatProvider? provider = null);
DateTime? ToDateTime(
string format,
DateTimeStyles style = Styles.DateTime,
IFormatProvider? provider = null);
DateTime? ToDateTimeSafe(
string format,
DateTimeStyles style = Styles.DateTime,
IFormatProvider? provider = null);
// .NET Core/.NET
DateTime? ToDateTime(
ReadOnlySpan<char> format,
DateTimeStyles style = Styles.DateTime,
IFormatProvider? provider = null);
DateTime? ToDateTimeSafe(
ReadOnlySpan<char> format,
DateTimeStyles style = Styles.DateTime,
IFormatProvider? provider = null);
DateTime? ToDateTime(
string[] formats,
DateTimeStyles style = Styles.DateTime,
IFormatProvider? provider = null);
DateTime? ToDateTimeSafe(
string[] formats,
DateTimeStyles style = Styles.DateTime,
IFormatProvider? provider = null);
DateTime? ToUtcDateTime(
DateTimeStyles style = Styles.UtcDateTime,
IFormatProvider? provider = null);
DateTime? ToUtcDateTimeSafe(
DateTimeStyles style = Styles.UtcDateTime,
IFormatProvider? provider = null);
DateTime? ToUtcDateTimeFromUnixTimeSeconds(
NumberStyles style = Styles.Integer,
IFormatProvider? provider = null);
DateTime? ToUtcDateTimeFromUnixTimeSecondsSafe(
NumberStyles style = Styles.Integer,
IFormatProvider? provider = null);
DateTime? ToUtcDateTimeFromUnixTimeMilliseconds(
NumberStyles style = Styles.Integer,
IFormatProvider? provider = null);
DateTime? ToUtcDateTimeFromUnixTimeMillisecondsSafe(
NumberStyles style = Styles.Integer,
IFormatProvider? provider = null);
// DateTimeOffset
DateTimeOffset? ToDateTimeOffset(
DateTimeStyles style = Styles.DateTimeOffset,
IFormatProvider? provider = null);
DateTimeOffset? ToDateTimeOffsetSafe(
DateTimeStyles style = Styles.DateTimeOffset,
IFormatProvider? provider = null);
DateTimeOffset? ToDateTimeOffset(
string format,
DateTimeStyles style = Styles.DateTimeOffset,
IFormatProvider? provider = null);
DateTimeOffset? ToDateTimeOffsetSafe(
string format,
DateTimeStyles style = Styles.DateTimeOffset,
IFormatProvider? provider = null);
// .NET Core/.NET
DateTimeOffset? ToDateTimeOffset(
ReadOnlySpan<char> format,
DateTimeStyles style = Styles.DateTimeOffset,
IFormatProvider? provider = null);
DateTimeOffset? ToDateTimeOffsetSafe(
ReadOnlySpan<char> format,
DateTimeStyles style = Styles.DateTimeOffset,
IFormatProvider? provider = null);
DateTimeOffset? ToDateTimeOffset(
string[] formats,
DateTimeStyles style = Styles.DateTimeOffset,
IFormatProvider? provider = null);
DateTimeOffset? ToDateTimeOffsetSafe(
string[] formats,
DateTimeStyles style = Styles.DateTimeOffset,
IFormatProvider? provider = null);
DateTimeOffset? ToDateTimeOffsetFromUnixTimeSeconds(
NumberStyles style = Styles.Integer,
IFormatProvider? provider = null);
DateTimeOffset? ToDateTimeOffsetFromUnixTimeSecondsSafe(
NumberStyles style = Styles.Integer,
IFormatProvider? provider = null);
DateTimeOffset? ToDateTimeOffsetFromUnixTimeMilliseconds(
NumberStyles style = Styles.Integer,
IFormatProvider? provider = null);
DateTimeOffset? ToDateTimeOffsetFromUnixTimeMillisecondsSafe(
NumberStyles style = Styles.Integer,
IFormatProvider? provider = null);
// TimeSpan
TimeSpan? ToTimeSpan(
IFormatProvider? provider = null);
TimeSpan? ToTimeSpanSafe(
IFormatProvider? provider = null);
TimeSpan? ToTimeSpan(
string format,
TimeSpanStyles style = Styles.TimeSpan,
IFormatProvider? provider = null);
TimeSpan? ToTimeSpanSafe(
string format,
TimeSpanStyles style = Styles.TimeSpan,
IFormatProvider? provider = null);
// .NET Core/.NET
TimeSpan? ToTimeSpan(
ReadOnlySpan<char> format,
TimeSpanStyles style = Styles.TimeSpan,
IFormatProvider? provider = null);
TimeSpan? ToTimeSpanSafe(
ReadOnlySpan<char> format,
TimeSpanStyles style = Styles.TimeSpan,
IFormatProvider? provider = null);
TimeSpan? ToTimeSpan(
string[] formats,
TimeSpanStyles style = Styles.TimeSpan,
IFormatProvider? provider = null);
TimeSpan? ToTimeSpanSafe(
string[] formats,
TimeSpanStyles style = Styles.TimeSpan,
IFormatProvider? provider = null);
// DateOnly: .NET 6+
DateOnly? ToDateOnly(
DateTimeStyles style = Styles.DateOnly,
IFormatProvider? provider = null);
DateOnly? ToDateOnlySafe(
DateTimeStyles style = Styles.DateOnly,
IFormatProvider? provider = null);
DateOnly? ToDateOnly(
string format,
DateTimeStyles style = Styles.DateOnly,
IFormatProvider? provider = null);
DateOnly? ToDateOnlySafe(
string format,
DateTimeStyles style = Styles.DateOnly,
IFormatProvider? provider = null);
// .NET Core/.NET
DateOnly? ToDateOnly(
ReadOnlySpan<char> format,
DateTimeStyles style = Styles.DateOnly,
IFormatProvider? provider = null);
DateOnly? ToDateOnlySafe(
ReadOnlySpan<char> format,
DateTimeStyles style = Styles.DateOnly,
IFormatProvider? provider = null);
DateOnly? ToDateOnly(
string[] formats,
DateTimeStyles style = Styles.DateOnly,
IFormatProvider? provider = null);
DateOnly? ToDateOnlySafe(
string[] formats,
DateTimeStyles style = Styles.DateOnly,
IFormatProvider? provider = null);
// TimeOnly: .NET 6+
TimeOnly? ToTimeOnly(
DateTimeStyles style = Styles.TimeOnly,
IFormatProvider? provider = null);
TimeOnly? ToTimeOnlySafe(
DateTimeStyles style = Styles.TimeOnly,
IFormatProvider? provider = null);
TimeOnly? ToTimeOnly(
string format,
DateTimeStyles style = Styles.TimeOnly,
IFormatProvider? provider = null);
TimeOnly? ToTimeOnlySafe(
string format,
DateTimeStyles style = Styles.TimeOnly,
IFormatProvider? provider = null);
// .NET Core/.NET
TimeOnly? ToTimeOnly(
ReadOnlySpan<char> format,
DateTimeStyles style = Styles.TimeOnly,
IFormatProvider? provider = null);
TimeOnly? ToTimeOnlySafe(
ReadOnlySpan<char> format,
DateTimeStyles style = Styles.TimeOnly,
IFormatProvider? provider = null);
TimeOnly? ToTimeOnly(
string[] formats,
DateTimeStyles style = Styles.TimeOnly,
IFormatProvider? provider = null);
TimeOnly? ToTimeOnlySafe(
string[] formats,
DateTimeStyles style = Styles.TimeOnly,
IFormatProvider? provider = null);
Known Issues
- Default encoding for files without BOM is UTF-8.
- Some strange Unicode characters in column names may cause errors in generated data context source code.
- Writing changed objects back to CSV is not directly supported, there is no
SubmitChanges()
. But you can use LINQPad'sUtil.WriteCsv
- Relations detection does not work well for similar files single class generation. However, you can query over related multiple files.
- Relations detection with file sorting might produce broken source code for similar files single class generation.
Troubleshooting
- In case of
Cannot load type 'LINQPad.User.***' from cache
error, use connection context menu Close all connections. - In case of
BadDataException: You can ignore bad data by setting BadDataFound to null
error, checkIgnore bad data
at Format section.
Authors
Credits
Tools
Libraries
- CsvHelper
- Fluent Assertions
- Humanizer
- IsExternalInit
- Microsoft.Bcl.HashCode (for LINQPad 5 only)
- Moq
- Nullable (for LINQPad 5 only)
- NUnit
- UnicodeCharsetDetector
- UTF.Unknown
- Windows API Code Pack
- Windows API Code Pack Shell
License
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net5.0-windows7.0 is compatible. net6.0 was computed. 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. net6.0-windows7.0 is compatible. 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. net7.0-windows7.0 is compatible. 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. net8.0-windows7.0 is compatible. 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. |
.NET Core | netcoreapp3.1 is compatible. |
-
.NETCoreApp 3.1
- CsvHelper (>= 33.0.1)
- Humanizer.Core (>= 2.14.1)
- LINQPad.Reference (>= 1.3.1)
- Microsoft-WindowsAPICodePack-Core-6.0 (>= 1.1.6)
- Microsoft-WindowsAPICodePack-Shell-6.0 (>= 1.1.6)
- UnicodeCharsetDetector.Standard (>= 1.1.9)
- UTF.Unknown (>= 2.5.1)
-
net5.0-windows7.0
- CsvHelper (>= 33.0.1)
- Humanizer.Core (>= 2.14.1)
- LINQPad.Reference (>= 1.3.1)
- Microsoft-WindowsAPICodePack-Core-6.0 (>= 1.1.6)
- Microsoft-WindowsAPICodePack-Shell-6.0 (>= 1.1.6)
- UnicodeCharsetDetector.Standard (>= 1.1.9)
- UTF.Unknown (>= 2.5.1)
-
net6.0-windows7.0
- CsvHelper (>= 33.0.1)
- Humanizer.Core (>= 2.14.1)
- LINQPad.Reference (>= 1.3.1)
- Microsoft-WindowsAPICodePack-Core-6.0 (>= 1.1.6)
- Microsoft-WindowsAPICodePack-Shell-6.0 (>= 1.1.6)
- UnicodeCharsetDetector.Standard (>= 1.1.9)
- UTF.Unknown (>= 2.5.1)
-
net7.0-windows7.0
- CsvHelper (>= 33.0.1)
- Humanizer.Core (>= 2.14.1)
- LINQPad.Reference (>= 1.3.1)
- Microsoft-WindowsAPICodePack-Core-6.0 (>= 1.1.6)
- Microsoft-WindowsAPICodePack-Shell-6.0 (>= 1.1.6)
- UnicodeCharsetDetector.Standard (>= 1.1.9)
- UTF.Unknown (>= 2.5.1)
-
net8.0-windows7.0
- CsvHelper (>= 33.0.1)
- Humanizer.Core (>= 2.14.1)
- LINQPad.Reference (>= 1.3.1)
- Microsoft-WindowsAPICodePack-Core-6.0 (>= 1.1.6)
- Microsoft-WindowsAPICodePack-Shell-6.0 (>= 1.1.6)
- UnicodeCharsetDetector.Standard (>= 1.1.9)
- UTF.Unknown (>= 2.5.1)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Add Parsing mode option.
Add Escape option.
Add Quote option.