Какой самый простой способ разбить список на основе критериев? - PullRequest
0 голосов
/ 21 ноября 2018

Допустим, у нас есть определение объекта, подобное этому,

class MyObject {
    int id;
    string name;
}

, и у нас есть список MyObjects.

List<MyObject> objectList

Теперь мне нужно разделить этот objectList на 2подсписки, основанные на том, какие объекты имеют ненулевое поле имени.

Итак, после операции мне нужно иметь 2 списка: objectsWithName, где поле имени не нулевое и objectsWithoutName, где поле имени нулевое (это непосредственный критерий, но я ищубольше к разделению на 2 группы с использованием предиката).

Какой самый простой способ достичь этого?Могу ли я сделать это за одну операцию?Использование LINQ разрешено.

Ответы [ 3 ]

0 голосов
/ 21 ноября 2018

Я думаю, что вы ищете что-то похожее на этот пример:

class MyObject 
{
    int id;
    string name;
}

var objectList = new List<MyObject>();

objectList.Add(new MyObject { name = "item 1" });
objectList.Add(new MyObject { name = string.Empty });
objectList.Add(new MyObject { name = "item 3" });

var objectsWithName = objectList.Where(x => !string.IsNullOrEmpty(x.name));
var objectsWithoutName = objectList.Except(objectsWithName);

Я создал 2 списка, в которых первый список содержит MyObject элементов со свойством name, не равным NULL,в противном случае ко второму.

0 голосов
/ 21 ноября 2018
public class MyObject
{
    public int Id { get; set; }
    public string Name { get; set; }
}

public class MyObjectLists
{
    private readonly List<MyObject> _objects;

    public List<MyObject> NullNameObjects
    {
        get
        {
            return _objects.Where(x => x.Name == null).ToList();
        }
    }

    public List<MyObject> NonNullNameObjects
    {
        get
        {
            return _objects.Where(x => x.Name != null).ToList();
        }
    }

    public MyObjectLists(List<MyObject> objects)
    {
        _objects = objects ?? throw new ArgumentNullException(nameof(objects));
    }
}

Используя код:

var list = new List<MyObject>
{
    new MyObject
    {
        Id = 1,
        Name = "John"
    },

    new MyObject
    {
        Id = 2
    },

    new MyObject
    {
        Id = 3,
        Name = "Mary"
    },

    new MyObject
    {
        Id = 4
    }
};

var objects = new MyObjectLists(list);

foreach (MyObject myObject in objects.NonNullNameObjects)
{
    Console.WriteLine($"Object with Id {myObject.Id} has a non-null name");
}

foreach (MyObject myObject in objects.NullNameObjects)
{
    Console.WriteLine($"Object with Id {myObject.Id} has a null name");
}
0 голосов
/ 21 ноября 2018

Подойдут два оператора LINQ:

var nameNotNull = objectList.Where(o => !string.IsNullOrEmpty(o.Name));
var nameNull = objectList.Where(o => string.IsNullOrEmpty(o.Name));

Конечно, вы можете использовать GroupBy или более эффективный оператор foreach.

Чтобы отобразить параметр foreach:

List<MyObject> nameNotNull = new List<MyObject>();
List<MyObject> nameNull = new List<MyObject>();

foreach (MyObject o in objectList)
{
    if (!string.IsNullOrEmpty(o.Name))
    {
        nameNotNull.Add(o);
    }
    else
    {
        nameNull.Add(o);
    }
}
...