سؤال

ولدي (C #) فئة تسمى هيت مع ItemID (الباحث) وخاصية التقييم (الباحث). I تخطي بقية التفاصيل ليبقيه قصيرة. الآن في قانون بلدي، ولدي قائمة ضخمة على الذي أنا بحاجة للقيام حدد التالية (في قائمة جديدة): أنا بحاجة للحصول على مجموع كل من Hit.Score لكل فرد Hit.ItemID، التي أمر بها نتيجة. حتى لو كنت وجود العناصر التالية في القائمة الأصلية

ItemID=3, Score=5
ItemID=1, Score=5
ItemID=2, Score=5
ItemID=3, Score=1
ItemID=1, Score=8
ItemID=2, Score=10

وينبغي أن تتضمن القائمة الناتجة يلي:

ItemID=2, Score=15
ItemID=1, Score=13
ItemID=3, Score=6

ويمكن لأي شخص أن تساعد؟

هل كانت مفيدة؟

المحلول

var q = (from h in hits
    group h by new { h.ItemID } into hh
    select new {
        hh.Key.ItemID,
        Score = hh.Sum(s => s.Score)
    }).OrderByDescending(i => i.Score);

نصائح أخرى

IEnumerable<Hit> result = hits.
   GroupBy(hit => hit.ItemID).
   Select(group => new Hit 
                   {
                      ItemID = group.Key,
                      Score = group.Sum(hit => hit.Score)
                   }).
   OrderByDescending(hit => hit.Score);
مرخصة بموجب: CC-BY-SA مع الإسناد
لا تنتمي إلى StackOverflow
scroll top