如何根据两种不同的条件进行不同的LINQ to XML查询?

时间:2010-04-01 12:01:35

标签: c# linq linq-to-xml

我们希望根据以下某些条件为查询结果分配两个结果:

var vAudioData = (from xAudioinfo in xResponse.Descendants(ns + "DIDL-Lite").Elements(ns + "item")

if((xAudioinfo.Element(upnp + "artist")!=null)
{
   select new RMSMedia
     {
        strAudioTitle = ((string)xAudioinfo.Element(dc + "title")).Trim()
     };
}
else
   select new RMSMedia
      {
         strGen = ((string)xAudioinfo.Element(dc + "Gen")).Trim()
      };

VarAudioData应包含if和else条件值。

我已经将if条件添加到项目中,我的需求是什么,我很确定我们不能使用if和else。

如果有任何其他方法可以帮助我们。

谢谢,

Subhen

1 个答案:

答案 0 :(得分:3)

from xAudioinfo in xResponse.Descendants(ns + "DIDL-Lite").Elements(ns + "item")
select new RSMedia
{
   strAudioTitle = (xAudioinfo.Element(upnp + "artist") != null) 
      ? ((string)xAudioinfo.Element(dc + "title")).Trim()
      : null,
   strGen = (xAudioinfo.Element(upnp + "artist") == null) 
      ? ((string)xAudioinfo.Element(dc + "Gen")).Trim()
      : null
}

你也可以使用一个看起来更好一点的联盟......但这同样有效。