我有一个XML文档:
<Item>
<ID>1</ID>
<Title>Title1</Title>
<Rank>1</Rank>
</Item>
<Item>
<ID>2</ID>
<Title>Title2</Title>
<Rank>2</Rank>
</Item>这个文档有十个项目,我遇到的问题是,我将选择Title2 ID 2和等级1。
for (int i = 0; i < 10; i++)
{
XmlNode titleNode = doc.GetElementsByTagName("Title", NAMESPACE).Item(i);
XmlNode asinNode = doc.GetElementsByTagName("ID", NAMESPACE).Item(i);
XmlNode SalesNode = doc.GetElementsByTagName("SalesRank", NAMESPACE).Item(i);
}这就是我加载文档的方式。
WebRequest request = HttpWebRequest.Create(url);
WebResponse response = request.GetResponse();
XmlDocument doc = new XmlDocument();
doc.Load(response.GetResponseStream());发布于 2011-09-15 06:46:53
XmlNode node = doc.SelectSingleNode("/Item[ID='"+i.ToString()+"']");
XmlNode titleNode = node.SelectSingleNode("Title");
XmlNode asinNode = node.SelectSingleNode("ID");
XmlNode rankNode = node.SelectSingleNode("Rank");发布于 2011-09-15 04:29:51
您可以使用XML (反)序列化:只需为Item创建一个快速类。XmlSerializer.Deserialize()文档中的完整示例。
当然,这只是解析XML的众多技术(XPath、Linq to XML等)中的一种。做你自己的选择。
发布于 2011-09-15 04:33:14
下面是一个使用XPath的工作示例,我相信这才是您真正需要的。
let doc = XmlDocument()
doc.LoadXml ("<As><A><B>1</B></A><A><B>2</B></A></As>")
let n = doc.SelectSingleNode("As/A[B/text() = '1']")https://stackoverflow.com/questions/7422499
复制相似问题