Parsing CSV Row To C# Object

With the widespread popularity of Nuget, there is a package for everything in C#. Parsing CSVs are no exception, but this feels like overkill. Parsing a csv, tsv or any value separated file in C# is not complicated and can be done very easily by simply breaking up the string. It takes a little more work when compared to the simplicity of json serialisation, but it is worth the effort. Particularly if you work for an orginazation that requires nuget packages to be reviewed before adding to an internal repository.

For this example, we will use the following CSV file. You can use this class with pretty much any file that has some kind of value separated data. Tabs are a common alternative that you can easily modify to use this example too.

title,description,price,creationDate<br>
"Converting a csv row to class","Use this class as a template to convert a csv row to a C# class",5.99,2019-01-01 00:00:00

The following class has properties based off the title of this CSV file. We want to skip the first row of course, it wont parse anyway as it will throw an exception due to price not being a decimal and creationDate not being a DateTime. By creating a method called TryParseRow, it falls inline with similar methods we have for the core data types in C# like Int, Double, DateTime and Decimal. The only difference is it doesn’t need to have an out property.

public class MyCSVRowClass
{
	public string Title;
	public string Description;
	public decimal Price;
	public DateTime CreationDate;
	
	
	public bool TryParseRow(string filerow)
	{
		try
		{
			var columns = filerow.Split(';');
			if (columns.Count() == 4) //dont accept a row with a different number of columns. It might be a new column at the end and cause no trouble. It may also be in the middle and screw everything up.
			{
				this.Title = columns[0];
				this.Description = columns[1];
				this.Price = Decimal.Parse(columns[2]); //optionally use try parse if you want to load the row even if one of the columns is invalid.
				this.CreationDate = DateTime.Parse(columns[3]);
				return true;
			}
			else
				return false;
		}
		catch (Exception e)
		{
			return false;
		}
	}
}

Using this class is a simple case of calling MyCSVRowClass.TryParseRow(csv row);. If the method returns a negative response, you know there was a parsing error with the line and you can ignore it. You may have a data file with some optional values in which case you may want to use the try parse methods inside the row parsing method. This way the code will continue parsing the line, even if one property is missing or invalid.

For ease of use, you could create a collection class that wraps up the parsing and file reading into one easy process.

public class MyCSVRowCollection
{
	public List<MyCSVRowClass> Rows;
	
	public void LoadFile(string file)
	{
		using{StreamReader file = new System.IO.StreamReader(file)}
		{		
			while((line = file.ReadLine()) != null)  
			{  
				var lineobj = new MyCSVRowClass();
				if(lineobj.TryParseRow(line))
					this.Rows.Add(lineobj);
			}
		}
	}
}

Related Articles

Related Questions

Issues with Saving Memories on ChatGPT

Hey everyone, I'm experiencing some trouble with using the memory feature on ChatGPT. It seems like new memories save when I type them out...

How Can I Keep My Android Phone Safe from a Hacked Home Network?

I've found out that my home network has been hacked, and I'm really worried about the safety of my Android phone, which is also...

Advice Needed for Upgrading a Computer Build as a Surprise Gift

Hey everyone! I want to share a little backstory. My younger brother has faced numerous challenges, including going in and out of rehab, but...

LEAVE A REPLY

Please enter your comment!
Please enter your name here

This site uses Akismet to reduce spam. Learn how your comment data is processed.

Latest Tools

Online Hash Generator – String to Hash Converter

Need to quickly generate a hash from a string? Whether you're verifying file integrity, securing data, or just experimenting with cryptographic tools, this simple...

Convert CSV To HTML Table

Need to quickly turn CSV data into an HTML table? Whether you're copying data from Excel, Google Sheets, or another spreadsheet, this tool makes...

Student Group Randomizer

Creating fair and balanced groups in the classroom can be time-consuming — especially when you're trying to avoid repetition, manage different skill levels, or...

Random Group Generator

Need to split a list of people, items, or ideas into random groups? Our free Random Group Generator makes it quick and easy. Whether...

Flip Text Upside Down – Free Online Tool

Ever wanted to flip your text upside down just for fun or to grab someone’s attention in a creative way? This free online Upside...

Raffle Ticket Generator

If you're running a fundraiser, charity draw, or local event and need raffle tickets fast, this free online tool lets you generate and print...

Latest Posts

Latest Questions