если вы просто хотите получить документ, чтобы поместить его куда-либо, то здесь не требуется большой логики / вычислений, для этого я бы использовал foreach.

ялсообщение об ошибке:

The type arguments for method 'System.Linq.Enumerable.Select<TSource,TResult>(System.Collections.Generic.IEnumerable<TSource>, System.Func<TSource,int,TResult>)' cannot be inferred from the usage. Try specifying the type arguments explicitly.

Первый метод не имеет проблем с использованиемIEnumerable<T>.Select() ? Где проблема со 2-м методом?

private void GetPupilsForSchoolclass()
{
   ObservableCollection<PupilViewModel> pupilsOC = new ObservableCollection<PupilViewModel>
   (                            _adminRepo.GetPupilsBySchoolclassId(_selectedSchoolclass.SchoolclassId).Select(p => new       PupilViewModel(p, _adminRepo))
   );
   SelectedSchoolclass.PupilListViewModel = pupilsOC;
}

private void GetDocumentsForPupil()
{
                ObservableCollection<Document> documentsOC = new ObservableCollection<Document>();
                IEnumerable<Document> documents = _docRepo.GetDocumentsByPupilId(_selectedPupil.Id);
                documents.Select(doc => documentsOC.Add(doc));
                SelectedPupil.Documents.DocumentList = documentsOC;
}

Ответы на вопрос(5)

подозреваемый этоAdd возвращаетсяvoid - это правильно? Если так, то нет способа спроецировать это наFunc<,> - толькоAction<T> - а такжеSelect хочетFunc<,>.

Select являетсяне так же, как косвенный `foreach

что оператор Return отсутствует при выборе элементов из коллекции.

Пример:

collection = nonLabors.Select(item =>
                {
                    item.Travel_Miles = item.Travel_Miles_Original != null ? decimal.Parse(item.Travel_Miles_Original) : 0;
                    return item;
                }).ToList();

Выберите этоне замена для foreach. Используйте это вместо:

ObservableCollection<Document> documentsOC = new ObservableCollection<Document>();
IEnumerable<Document> documents = _docRepo.GetDocumentsByPupilId(_selectedPupil.Id);
foreach(var doc in documents)
{
    documentsOC.Add(doc);
}
SelectedPupil.Documents.DocumentList = documentsOC;
 Elisabeth08 янв. 2011 г., 20:46
если вы просто хотите получить документ, чтобы поместить его куда-либо, то здесь не требуется большой логики / вычислений, для этого я бы использовал foreach.

ObservableCollection<Document>.Add? ТипичноAdd метод возвращает void. Вы не можете использовать LINQSelect выполнить процедуру для всех элементов, только функцию, которая возвращает что-то (иначе, где будет возвращаемое значениеSelect родом из?). Вместо этого вы можете использовать LINQForEach или цикл Cachach foreach.

Решение Вопроса

documentsOC.Add возвращаетсяvoid.
Нет смысла (и невозможно) писать.Select<Something, void>(...).

То, что вы пытаетесь сделать, не может работать в первую очередь;Select ленив и не вызывает вашу функцию, пока вы не перечислите результаты.

Вы должны использовать обычныйforeach петля.

 Elisabeth07 янв. 2011 г., 21:01
черт возьми ... в течение минуты буря ответов приходит в центр города: P ах да, это было слишком закреплено на модели представления, но достаточно IEnumerable для Ctor коллекции OCollection => ObservableCollection <Document> documentsOC = new ObservableCollection <Document> (_ docRepo .GetDocumentsByPupilId (_selectedPupil.Id));

Ваш ответ на вопрос