Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mookid8000/semicolon
:link: Just a small and extensible CSV parser
https://github.com/mookid8000/semicolon
Last synced: about 2 months ago
JSON representation
:link: Just a small and extensible CSV parser
- Host: GitHub
- URL: https://github.com/mookid8000/semicolon
- Owner: mookid8000
- Created: 2019-10-31T10:11:48.000Z (about 5 years ago)
- Default Branch: master
- Last Pushed: 2024-06-10T12:52:21.000Z (7 months ago)
- Last Synced: 2024-06-10T14:38:19.317Z (7 months ago)
- Language: C#
- Homepage:
- Size: 1.71 MB
- Stars: 2
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
Awesome Lists containing this project
README
# Semicolon
It's a CSV parser. 🙂
Let's say you're handed some CSV like this:
```
Player ID;Name;Duration (s)
734;Joe;65
78439;Moe;63
12342;Bo;67
```and you want to parse that somehow. This CSV parser can help you. 😁
You start by creating a type with properties for the columns you want to extract (it doesn't have to be all of them):
```csharp
class CsvRow
{
[CsvColumn("Player ID")]
public string Id { get; set; }[CsvColumn("Name")]
public string Name { get; set; }[CsvColumn("Duration (s)", Binder = typeof(ConvertSecondsToTimeSpanBinder))]
public TimeSpan Duration { get; set; }
}
```As you can see, the CSV column name is bound to columns from the CSV text by specifying the column name with the `[CsvColumn(...)]` attribute.
Another thing to note: Since the duration in the CSV text is specified as an integer (the number of seconds), and we want the value as a `TimeSpan`, we make the parser use our own custom binder, `ConvertSecondsToTimeSpanBinder`:
```csharp
class ConvertSecondsToTimeSpanBinder : IBinder
{
public object GetValue(CultureInfo culture, string str) => TimeSpan.FromSeconds(int.Parse(str));
}
```Nice. Let's parse the CSV:
```csharp
var parser = new Parser();var rows = parser.ParseCsv(CsvText);
```If we now call `rows.DumpTable()` (extension method from [Testy](https://github.com/rebus-org/Testy)), we get this:
```
+-------+------+----------+
| Id | Name | Duration |
+-------+------+----------+
| 734 | Joe | 00:01:05 |
| 78439 | Moe | 00:01:03 |
| 12342 | Bo | 00:01:07 |
+-------+------+----------+```
which is what we hoped for. 😎