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;
}
我似乎沒有找到Linq.XElement或Linq.XDocument中的SelectSingleNode或XPathSelectElement方法。 – 2010-02-24 12:17:06
我缺少System.Xml.XPath命名空間。 doc.XPathSelectElement(「./ metadata/field [@ name ='SOURCE']」)。Value works。 – 2010-02-24 13:58:40