2010-02-24 140 views
1

我試圖從XML字符串中編寫「文檔」列表,但我想知道獲取某個屬性節點的值的最佳方法是什麼。讀取具有Xdocument特定屬性的節點的值

更具體地說,在示例中,我想將aDocument.Source的值設置爲具有「name」屬性的「Source」值的「field」節點的文本「The Source」。

示例XML:

<doc> 
     <docitem>3</docitem> 
     <docid>129793</docid> 
     <doctitle>Some Title</doctitle> 
     <docdate>2009-07-03</docdate> 
     <metadata> 
     <field name="Date">2009-07-03 14:45:00</field> 
     <field name="SourceArea">The Source Area</field> 
     <field name="Source">The Source</field> 
     <field name="Organisation">Some Organisation</field> 
     </metadata> 
     <summary> 
     <summarytext>Some Summary</summarytext> 
     </summary> 
    </doc> 

示例代碼

protected override List<Document> GetDocuments(string xmlString) 
     { 
      //Parse the string 
      XDocument xDocument = XDocument.Parse(xmlString); 

      //Create a List of Document objects, from the doc xml element. 
      List<Document> documents = (from doc in xDocument.Descendants("doc") 
             select new Document 
             { 
              DocId = Convert.ToInt32(doc.Element("docid").Value), 
              DocTitle = doc.Element("doctitle").Value, 
              DocDateTime = DateTime.Parse(doc.Element("docdate").Value), 
              DocSummary = doc.Element("summary").Value, 
              DocBody = "", 
              DocUrl = doc.Element("docid").Value, 
              Source = "" //CODE NEEDED 
             } 
             ).ToList<Document>(); 



      return documents; 

     } 

回答

2

您可以使用XPath XmlDocument的

xmlDocument.SelectSingleNode("doc/metadata/field[@name='Source']").InnerText 

或者更好的,你可以使用LINQ到XML和XPath

XDocument doc = XDocument.Parse(/*XML here*/); 
doc.XPathSelectElement("doc/metadata/field[@name='Source']").Value 
+0

我似乎沒有找到Linq.XElement或Linq.XDocument中的SelectSingleNode或XPathSelectElement方法。 – 2010-02-24 12:17:06

+1

我缺少System.Xml.XPath命名空間。 doc.XPathSelectElement(「./ metadata/field [@ name ='SOURCE']」)。Value works。 – 2010-02-24 13:58:40

相關問題