2012-03-07 87 views
0

我有一個XML文件:解析xml。返回一個對象不是集合

<Result>Ok</Result> 
    <Error></Error> 
    <Remark></Remark> 
    <Data> 
    <Movies> 
     <Movie ID='2'> 
     <Name><![CDATA[TestName]]></Name> 
     <Duration Duration='170'>2h 50min</Duration>    
     <Properties> 
      <Property Name='11'><![CDATA[1111110]]></Property> 
     </Properties> 
     <Rental from_date='' to_date=''> 
      <SessionCount></SessionCount> 
      <PU_NUMBER></PU_NUMBER> 
     </Rental> 
     </Movie> 
    </Movies> 
    </Data> 
</XML> 

代碼pasring xml文件:

var results = from element in XDocument.Parse(queryResponse).Descendants("Movie") 
          select new BaseEvent 
          { 
           OID = (int)element.Attribute("ID"), 
           Subject = (string)element.Element("Name"), 
           Duration = (int)element.Element("Duration").Attribute("Duration") 
          }; 

的問題,即Descedants retruns IEumerable<BaseEvent>,但我想,這將是BaseEvent。我怎樣才能做到這一點?

回答

2

只需使用First()Last()Single()FirstOrDefault()

個人而言,我會做到這一點最初,而不是做這一切在一個查詢:

var element = XDocument.Parse(queryResponse) 
         .Descendants("Movie") 
         .FirstOrDefault(); 
if (element == null) 
{ 
    // Handle the case of no movies 
} 
else 
{ 
    var baseEvent = new BaseEvent 
        { 
         OID = (int) element.Attribute("ID"), 
         Subject = (string) element.Element("Name"), 
         Duration = (int) element.Element("Duration") 
               .Attribute("Duration") 
        }; 
    // Use baseEvent 
} 
1

添加.First()得到第一個元素:

from element in XDocument.Parse(queryResponse).Descendants("Movie") 
          select new BaseEvent 
          { 
           OID = (int)element.Attribute("ID"), 
           Subject = (string)element.Element("Name"), 
           Duration = (int)element.Element("Duration").Attribute("Duration") 
          }.First(); 

你可以選擇使用FirstOrDefault()(如果沒有這樣的節點),Last()Single()