4

一直在寻找答案,但找不到任何东西 - 我很新,所以也许我没有找到正确的关键词?

这是我正在使用的 XML 示例

<database>
<book>
<title>A</title>
<author>
  <name>1</name>
</author>
</book>
<book>
<title>B</title>
<author>
  <name>2</name>
</author>
<author>
  <name>3</name>
</author>
<author>
  <name>4</name>
</author>
<author>
  <name>5</name>
</author>
</book>
</database>

我正在尝试使用 C# XMLDocument 来获取 A 书作者 1,然后获取 B 书作者 1、2、3、4、5

到目前为止,我正在使用的代码是遍历所有作者,所以我得到书 A author 1、2、3、4、5

我到目前为止的代码大致如下

XmlDocument doc = new XmlDocument();
doc.Load("myxmlfile");
XmlNode root = doc.SelectSingleNode("database");
XmlNodeList nodelist = root.SelectNodes("book");

foreach (XmlNode n in nodelist)
        {

XmlNodeList authors = root.SelectNodes(".//author");
book.authorstring = "";
foreach (XmlNode author in authors)
       {
       book.authorstring = book.authorstring+author.SelectSingleNode("name").InnerText + ", ";
       }
}

我读到了一些地方,如果我在“ // ”之前使用“ . ”,它将“锚定”到当前节点,但它似乎没有工作并且正在循环遍历所有节点

我做错了什么或错过了什么?

4

3 回答 3

7

如果我理解正确,您的错误就在这一行:

XmlNodeList authors = root.SelectNodes(".//author");

它应该是

XmlNodeList authors = n.SelectNodes(".//author");
于 2012-10-26T05:50:29.467 回答
2

对于未来的读者,我偶然发现了这篇文章,但我忘记在.我的 xPath 中添加一个。

即(这是powershell,但没关系),

这是错误的并返回从根节点找到的第一个节点:

$descriptionNode = $someNode.SelectSingleNode("//Description")

这是正确的,并将第一个节点作为节点的子节点返回:

$descriptionNode = $someNode.SelectSingleNode(".//Description")

这当然是因为//会在任何地方查询,并且./会相对查询。很清楚的解释,但很容易错过,需要一些时间才能找到。

方便的备忘单: https ://devhints.io/xpath

于 2021-01-13T15:10:46.047 回答
1

使用 linq2XML.. 使用起来很简单

XElement doc=XElement.Load("yourXML.xml");

var lstBooks=doc.Descendants("book").Select(x=>
new
{
    name=x.Element("title").Value,
    authors=x.Elements("author").Select(y=>y.Element("name").Value)
}
);

lstBooks现在包含所有需要的数据

您现在可以执行此操作

foreach(var book in lstBooks)
{
book.name;//Name of the book
    foreach(var author in book)
    {
        author;//name of the author
    }
}
于 2012-10-26T06:29:04.580 回答