Как добавить объекты в неизменяемый общий список с помощью метода расширения Select () - PullRequest
1 голос
/ 09 июня 2011

У меня есть неизменный список.

В приведенном ниже g.Select (...) я делаю .ToList (), который помещается в MemberIdList.Я не хочу создавать новый список с помощью ToList (), а хочу добавить каждую строку r.Field в неизменяемый список внутри объекта объекта.

Как я могу это сделать?

var groupedCollection = table.AsEnumerable()
        .GroupBy(row => new
        {
            UType = row.Field<string>("UnitType"),
            UZoom = row.Field<string>("UnitZoom"),
            MZoom = row.Field<string>("MemberZoom"),
        });

    var unitCollection = groupedCollection
        .Select(g => new Unit
        {
            UnitType = g.Key.UType,
            UnitZoom = g.Key.UZoom,
            MemberZoom = g.Key.MZoom,
            MemberIdList = g.Select(r => r.Field<string>("TestId")).ToList(),
        });

    List<Unit> units = unitCollection.ToList();


public class Unit
{
    public Unit()
    {
        MemberIdList = new List<String>();
    }

    public String UnitType { get; set; }
    public String UnitZoom { get; set; }
    public String MemberZoom { get; set; }
    public int MemberOrder { get; set; }

    public List<String> MemberIdList { get; private set; }
}

1 Ответ

2 голосов
/ 09 июня 2011

Почему бы просто не создать конструктор для Unit, который принимает данные для MemberIdList, например:

public Unit(IEnumerable<string> memberIdList)
{
    MemberIdList = new List<string>(memberIdList);
}

и измените свой выбор на:

.Select(g => new Unit(g.Select(r => r.Field<string>("TestId")))
{
    UnitType = g.Key.UType,
    UnitZoom = g.Key.UZoom,
    MemberZoom = g.Key.MZoom
});
...