.NET Tutorials, Forums, Interview Questions And Answers
Welcome :Guest
Sign In
Win Surprise Gifts!!!

Home >> Articles >> C# >> Post New Resource Bookmark and Share   

 Subscribe to Articles

How to Sort a Collection by it's Property Name?

Posted By:Kunal Chowdhury       Posted Date: August 21, 2010    Points: 25    Category: C#    URL: http://www.dotnetspark.com  

Here I described how to sort a collection by it's property name.

Several times we need to sort a collection based on some property name e.g. we have an Employee collection of type Person. Person consists of EmpId, Name, Age etc. Now as an user, I need to sort the collection in ascending or descending order either by EmpId, Name or Age. So, how can I do this? In this post, I will describe you a simple technique by which you will be easily able to sort the collection without writing the implementation for each logic. Read the complete article and at the end if you have any suggestions, please don't forget to share. Feedbacks are always highly appreciated. Before going to the actual implementation, let us create our base class i.e. Employee having some properties like EmpId and Name.
public class Employee
public string Name { get; set; }
public string EmpId { get; set; }
Now, it's time to create a class which will implement the sorting algorithm. Let us create a class named "FieldSort" and implement the IComparer interface. Let us make it little bit generic. Hence create the class of generic type T and implement it from the generic IComparer interface type of T. IComparer has a method called Compare(). Just implement it in your class. Now inside the Compare() method get the PropertyInfo by doing a reflection and get the value of the property of each comparable object as string. Use string.Compare() to compare between the values and return the comparison result as integer. Here is the full implementation of the class:
using System;
using System.Collections.Generic;
using System.Reflection;

namespace SortLibrary
public class FieldSort : IComparer
private string propertyName = string.Empty;
private SortOrder sortOrder = SortOrder.ASC;
private StringComparison stringComparisonMethod =

/// Initializes a new instance of the  class.
/// Name of the property.
/// The sort order.
/// The compare method.
public FieldSort(string propertyName,
SortOrder sortOrder = SortOrder.ASC,
StringComparison compareMethod =
this.propertyName = propertyName;
this.sortOrder = sortOrder;
this.stringComparisonMethod = compareMethod;

/// Compares the specified x with specified y.
/// The original object x.
/// The object y which will be compared.
public int Compare(T x, T y)
PropertyInfo propertyInfo = x.GetType().GetProperty(propertyName);

if (propertyInfo != null)
string xValue = propertyInfo.GetValue(x, null).ToString();
string yValue = propertyInfo.GetValue(y, null).ToString();

if (xValue != null && yValue != null)
return (sortOrder == SortOrder.ASC)
? string.Compare(xValue, yValue, stringComparisonMethod)
: string.Compare(yValue, xValue, stringComparisonMethod);
return 0;
Now let us discuss how to call this sort in our application. If you have the list collection of your Employee informations, you need to create the instance of the class FieldSort of type Employee with the proper arguments and pass as a parameter to the method Sort() of the List collection. That's it. Your collection will sort automatically based on the "propertyName" argument you passed in the FieldSort class instance. You don't need to call the Compare() method. The IComparer interface will take care of it for you. Let's see the calling method:
EmployeeList.Sort(new FieldSort("Name",
Once called, you will see the collection sorted according to your algorithm. Here's the original collection used for this example:

Once sort is done, you will see the sorted collection (descending order):

So, go ahead and use this class wherever you need. Don't forget to provide your feedbacks. These are always welcome.

 Subscribe to Articles


Further Readings:


No response found. Be the first to respond this post

Post Comment

You must Sign In To post reply
Find More Articles on C#, ASP.Net, Vb.Net, SQL Server and more Here

Hall of Fame    Twitter   Terms of Service    Privacy Policy    Contact Us    Archives   Tell A Friend