LINQ to JSON: InvalidOperationException: Lambda Параметр не в области

Я пытаюсь выполнить пример кода LINQ в JSON (упомянутый ниже), но он дает мне следующую ошибку

Трассировки стека:

[InvalidOperationException: параметр Lambda отсутствует в области видимости]

Код, который я выполняю:

      JObject rss =
          new JObject(

                new JProperty("id", "James Newton-King"),
                new JProperty("name", "http://james.newtonking.com"),
                new JProperty("data", "James Newton-King's blog."),
                new JProperty("children",
                  new JArray(
                    from p in mwsysbot.Software
                    where p.SoftwareName == name
                    select new JObject(                            
                      new JProperty("id",p.SoftwareUUID),
                      new JProperty("name", p.SoftwareName)         
                    )
                  )
                 )
               );

Также, когда я удаляю строку «новый JProperty» («name», p.SoftwareName), код выполняется отлично.

Зачем?

json,linq-to-objects,json.net,

5

Ответов: 2


3

Я попробовал это, и это сработало для меня ...

     IQueryable<Software> soft = (from s in mwsysbot.Software
                                                     select s).ToList();

JObject rss =
           new JObject(
                     new JProperty("id", "James Newton-King"),
                     new JProperty("name", "http://james.newtonking.com"),
                     new JProperty("data", "James Newton-King's blog."),
                     new JProperty("children", new JArray(
                         from m in soft
                         select new JObject(
                             new JProperty("id",m.SoftwareName),
                             new JProperty("name", m.SoftwareName),
                             new JProperty("children",new JArray())
                             )
                         ))


             );

Я не знаю причины!

Похоже, мы можем использовать только структуру данных «Список» в вышеуказанном месте?


0

Linq может попытаться ленить загрузку SoftwareName. Попробуйте использовать DTO и загрузите имя параметра перед созданием нового объекта.

JSON, LINQ к объектам, json.net,
Похожие вопросы
Яндекс.Метрика