1

我有以下xml:

<?xml version="1.0"?>
<catalog>
   <book id="bk101">
      <author>Gambardella, Matthew</author>
      <title>XML Developer's Guide</title>
      <genre>Computer</genre>
      <price>44.95</price>
      <publish_date>2000-10-01</publish_date>
      <description>An in-depth look at creating applications 
      with XML.</description>
   </book>
   <book id="bk102">
      <author>Ralls, Kim</author>
      <title>Midnight Rain</title>
      <genre>Fantasy</genre>
      <price>5.95</price>
      <publish_date>2000-12-16</publish_date>
      <description>A former architect battles corporate zombies, 
      an evil sorceress, and her own childhood to become queen 
      of the world.</description>
   </book>
</catalog>

我找到了名为“午夜雨”的标题。现在我想知道他的父母是谁,这样我就可以使用<author>文本节点。我试过类似的东西:

  var xpath = "../*[local-name() != 'title']";
       xml.Load(xmlalltext);
       var xl1 = xml.SelectNodes(xpath);
       MessageBox.Show(xl1.Item(0).InnerText.ToString());
4

3 回答 3

3

如果您已经找到标题节点并且正在寻找父节点,则只需选择当前节点的父节点即可。

var parentNode = titleNode.SelectSingleNode("..");

如果您正在寻找作者节点:

var authorNode = titleNode.SelectSingleNode("../author");

或者,您可以查找前面或后面的兄弟姐妹:

var authorNode = titleNode.SelectSingleNode("following-sibling::author") ?? titleNode.SelectSingleNode("preceding-sibling::author");

编辑:要回答您的评论,如果您只有标题的字符串,那么您可以使用以下内容来获取作者:

string xml = @"xml...";
var doc = XDocument.Parse(xml);
string author = doc
    .Descendants("book")
    .Where(x => x.Element("title").Value == "Midnight Rain")
    .Select(x => x.Element("author").Value)
    .FirstOrDefault();
于 2012-05-14T09:41:26.043 回答
1

using XLinq

sample.xml(in below snipped) contains xml data

        XElement root = XElement.Parse(File.ReadAllText("sample.xml"));

        var matchingBooks = root.Descendants().Where(i=>String.Equals(i.Value,"Midnight Rain")).Select(i=>i.Parent) ;
        var authors = matchingBooks.Elements("author");

Output in LinqPad

 matchingBooks.Dump();

authors.Dump();

<book id="bk102">
        <author>Ralls, Kim</author>
        <title>Midnight Rain</title>
        <genre>Fantasy</genre>
        <price>5.95</price>
        <publish_date>2000-12-16</publish_date>
        <description>A former architect battles corporate zombies, 
            an evil sorceress, and her own childhood to become queen 
            of the world.</description>
        </book>

<author>Ralls, Kim</author>
于 2012-05-14T09:43:24.483 回答
0

You can use this xpath expession to get author node

"/catalog/book[title='Midnight Rain']/author"

or this to get parent node

"/catalog/book[title='Midnight Rain']"

eg.

 var result = xml.SelectNodes(string.Format("/catalog/book[title='{0}']/author", "Midnight Rain"))
于 2012-05-14T09:44:17.337 回答