Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Get a distinct list of ids from IEnumerable<T>

I have an IEnumerable that I want to get all the distinct MaterialIDs. I have code that is working but I was wondering if there is a better way possible using LINQ. Here's the code I have:

    private IEnumerable<int> GetDistinctMaterialIDs(IEnumerable<TankReading> tankReadings)
    {
        var distinctMaterialIDs = new List<int>();
        foreach (var tankReading in tankReadings)
        {
            if (!distinctMaterialIDs.Contains(tankReading.MaterialID))
            {
                distinctMaterialIDs.Add(tankReading.MaterialID);
            }
        }
        return distinctMaterialIDs;
    }

Any help would be appreciated as I am learning how LINQ can help me.

like image 406
mpenrow Avatar asked Aug 03 '10 16:08

mpenrow


1 Answers

tankReadings.Select(o => o.MaterialID).Distinct();
like image 179
Kirk Woll Avatar answered Nov 10 '22 04:11

Kirk Woll