c# - Xml 节点的 Xml 后代

标签 c# xml xpath

这里是一个简化的mxl结构'xml',

<store>

<book_1>
   <author_1><name>Alice</name><age>30</age></author_1>
   <author_2><name>Bob</name><age>31</age></author_2>
<book_1>
   <author_1><name>Charley</name><age>29</age></author_1>
   <author_2><name>Dory</name><age>25</age></author_2> 
<book_1>    
</store>

这是我尝试过的;

 XmlDocument submission = new XmlDocument();
   submission.LoadXml(xml);
    var bookNodes = submission.SelectNodes("//*[starts-with(local-name(),'book_')]");

这给了我一个书单。

 foreach (XmlNode book in bookNodes)
  {
    //I want to do something like to find book authors for the book in context e.g. for the first book I just want nodes for Alice and Bob.
   // var bookAuthors = book.SelectNodes("decendants::[starts-with(local-name(),'author_')"); 

  }

我怎样才能开始检查后代元素?

编辑: 好像打错了...

var bookAuthors = book.SelectNodes("descendant::*[starts-with(local-name(),'MeritCriterion_')]");

最佳答案

您可以使用以下 XPath 语法访问您的后代节点:

XmlDocument submission = new XmlDocument();
submission.LoadXml(xml);

var bookNodes = submission.SelectNodes("//*[starts-with(local-name(),'book_')]");

foreach (XmlNode book in bookNodes)
{
    var author = book.SelectNodes("descendant::*[starts-with(local-name(),'author_')]");

    foreach (XmlNode authorInfo in author)
    {
        Console.WriteLine(authorInfo .InnerText);
    }
}

简而言之,您需要访问 descendant::(all)[starts-with] 否则您只是试图访问您的 XPath 中的任何后代。 :)

关于c# - Xml 节点的 Xml 后代,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50402395/

相关文章:

c# - 在 C# 中处理非常大的整数

c# - WPF 拦截全局鼠标移动(就像在 Windows 窗体中使用 IMessageFilter)

java - 向 SOAP 消息添加内容(基本)

javascript - 有没有办法从链接的 xpath 获取 JavaScript 中链接的目的地?

c# - 当绑定(bind)属性为空时,WPF DataGrid 显示 'NULL'

c# - Entity Framework - 性能计数

java - 如何在 JSP 中从该 XML 中提取值

PHP:XML 文件到字符串,使用 asXML() 更快的 file_get_contents 或 simplexml_load_file

sql - 带有命名空间的 PostgresQL xpath

python - Scrapy:向 xpath 数组添加变量