Squeak.ru - шаблоны программирования

Сравнение двух списков объектов и изменение свойства

Я пытаюсь сравнить два списка объектов и создать из них новый список.

У меня есть класс с именем Item.

public class Item
{
    public string ItemNumber;
    public string OptionNumber;
    public int Count;
}

У меня есть два списка элементов -processItems и currentItems.

List<Item> processedItems = new List<Item>();  
List<Item> currentItems = new List<Item>();

Мне нужен список обработанных элементов.

Однако, если ItemNumber и OptionNumber существуют в currentItems, я хочу, чтобы свойство Count было суммой двух значений (значение в processingItems и currentItems).

Пример ожидаемых и фактических значений.

processedItems.Add(new Item() { ItemNumber = "123456", OptionNumber = "123", Count = 1 });
processedItems.Add(new Item() { ItemNumber = "123456", OptionNumber = "126", Count = 2 });
processedItems.Add(new Item() { ItemNumber = "112233", OptionNumber = "111", Count = 1 });
processedItems.Add(new Item() { ItemNumber = "112244", OptionNumber = "222", Count = 4 });

currentItems.Add(new Item() { ItemNumber = "123456", OptionNumber = "123", Count = 1 });
currentItems.Add(new Item() { ItemNumber = "123456", OptionNumber = "126", Count = 2 });
currentItems.Add(new Item() { ItemNumber = "998877", OptionNumber = "111", Count = 1 });
currentItems.Add(new Item() { ItemNumber = "112244", OptionNumber = "222", Count = 0 });

Из приведенного выше примера я пытаюсь получить следующий вывод:

List<Item> output = new List<Item>();

output.Add(new Item() { ItemNumber = "123456", OptionNumber = "123", Count = 2 });
output.Add(new Item() { ItemNumber = "123456", OptionNumber = "126", Count = 4 });
output.Add(new Item() { ItemNumber = "112233", OptionNumber = "111", Count = 1 });
output.Add(new Item() { ItemNumber = "112244", OptionNumber = "222", Count = 4 });

Нужно ли мне использовать Concat? У меня сейчас что-то вроде этого

var output = processedItems.Select(x => new Item
{
    ItemNumber = x.ItemNumber,
    OptionValue = x.OptionValue,
    Count = x.Count + (currentItems.FirstOrDefault(y => y.ItemNumber == x.ItemNumber && y.OptionValue == x.OptionValue).Count)
}).Concat(currentItems
    .Where(x => processedItems.Any(y => y.ItemNumber == x.ItemNumber && y.OptionValue == x.OptionValue)))
    .Select(x => new Item
    {
        ItemNumber = x.ItemNumber,
        OptionValue = x.OptionValue,
        Count = x.Count
    })
    .ToList();
17.04.2020

  • Что такое свойство Discrepancy, у класса Item его нет 17.04.2020
  • @PavelAnikhouski Извините, должен быть граф. Отредактировано. 17.04.2020

Ответы:


1

Вы можете использовать GroupJoin и выберите элементы из processedItems, используя currentItems только для sum из count между присоединяемыми элементами, например следующий код:

var output =
    processedItems
        .GroupJoin(
            currentItems,
            prd => new { prd.ItemNumber, prd.OptionNumber },
            sel => new { sel.ItemNumber, sel.OptionNumber },
            (prd, sel) => new Item
            {
                ItemNumber = prd.ItemNumber,
                OptionNumber = prd.OptionNumber,
                Count = sel.Sum(s => s.Count) + prd.Count
            })
        .ToList();

Демо:

foreach (Item item in output)
{
    Console.WriteLine($"ItemNumber:{item.ItemNumber}, OptionNumber:{item.OptionNumber}, Count:{item.Count}");
}

Результат

ItemNumber:123456, OptionNumber:123, Count:2
ItemNumber:123456, OptionNumber:126, Count:4
ItemNumber:112233, OptionNumber:111, Count:1
ItemNumber:112244, OptionNumber:222, Count:4

Я надеюсь, что это поможет вам решить проблему.

17.04.2020
  • @Bhav как насчет моего ответа, для меня это просто работа. 17.04.2020

  • 2

    Я часто предпочитаю использовать .ToLookup в таких ситуациях:

    var lookup = currentItems.ToLookup(x => new { x.ItemNumber, x.OptionNumber }, x => x.Count);
    
    var output =
        processedItems
            .Select(x => new Item
            {
                ItemNumber = x.ItemNumber,
                OptionNumber = x.OptionNumber,
                Count = x.Count + lookup[new {x.ItemNumber, x.OptionNumber }].Sum()
            })
            .ToList();
    

    В качестве альтернативы, присоединение к группе является правильным способом.

    var output =
    (
        from x in processedItems
        join y in currentItems
            on new { x.ItemNumber, x.OptionNumber }
            equals new { y.ItemNumber, y.OptionNumber }
            into gys
        select new Item()
        {
            ItemNumber = x.ItemNumber,
            OptionNumber = x.OptionNumber,
            Count = x.Count + gys.Sum(z => z.Count)
        }
    ).ToList();
    
    17.04.2020
  • Присоединение к группе - это путь. Оба ответа показывают синтаксис запроса и метода, что тоже здорово. 17.04.2020
  • Новые материалы

    Угловая структура архитектуры
    Обратите внимание, что эта статья устарела, я решил создать новую с лучшей структурой и с учетом автономных компонентов: https://medium.com/@marekpanti/angular-standalone-architecture-b645edd0d54a..

    «Данные, которые большинство людей используют для обучения своих моделей искусственного интеллекта, поставляются со встроенным…
    Первоначально опубликовано HalkTalks: https://hacktown.com.br/blog/blog/os-dados-que-a-maioria-das-pessoas-usa-para-treinar-seus-modelos-de-inteligencia-artificial- ja-vem-com-um-vies-embutido/..

    Сильный ИИ против слабого ИИ: различия парадигм искусственного интеллекта
    В последние годы изучению и развитию искусственного интеллекта (ИИ) уделяется большое внимание и прогресс. Сильный ИИ и Слабый ИИ — две основные парадигмы в области искусственного интеллекта...

    Правильный способ добавить Firebase в ваш проект React с помощью React Hooks
    React + Firebase - это мощная комбинация для быстрого и безопасного создания приложений, от проверки концепции до массового производства. Раньше (знаете, несколько месяцев назад) добавление..

    Создайте API с помощью Python FastAPI
    Создание API с помощью Python становится очень простым при использовании пакета FastAPI. После установки и импорта вы можете создать приложение FastAPI и указать несколько конечных точек. Каждой..

    Веселье с прокси-сервером JavaScript
    Прокси-серверы JavaScript — это чистый сахар, если вы хотите создать некоторую общую логику в своих приложениях, чтобы облегчить себе жизнь. Вот один пример: Связь клиент-сервер Мы..

    Получить бесплатный хостинг для разработчиков | Разместите свой сайт за несколько шагов 🔥
    Статические веб-сайты — это веб-страницы с фиксированным содержанием и его постоянным содержанием. Но теперь статические сайты также обрабатывают динамические данные с помощью API и запросов...