- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在尝试查找某个节点的祖先。我们称它为“NodeA”。我得到了“NodeA”节点的列表,并想查找其祖先以检查某个属性值。这是我检索所有“NodeA”节点的代码:
String xPathExpression = "//*[local-name()='NodeA']";
XPathNodeIterator nodeSet = (XPathNodeIterator)navigator.Evaluate(xPathExpression);
foreach (XPathNavigator item in nodeSet)
{
// Iterate through ancestors in here.
}
在“//Iterate through ancestors in here”区域中,我可以通过表达式评估我的节点并通过以下方式获取祖先列表(对于每个“NodeA”):
XPathNavigator item;
var ancestorExpression = string.Format("//*[name()='{0}']/ancestor-or-self::*", item.Name);
XPathNodeIterator ancestors = (XPathNodeIterator)navigator.Evaluate(ancestorExpression);
但是,这似乎是多余的,因为我有原始的 xml 和一个 XPathNavigator 实例,我是否可以在那个时候获取我的祖先而不必通过导航器计算表达式?类似于以下内容(其中 item 是 XPathNavigator 类型):
item.GetAncestors();
或
Helper.GetAncestors(fullXML, item)
我知道该项目上有一个 SelectAncestors 方法,但我没能让它发挥作用。但如果是这样,一个例子将不胜感激
<NodeAGrandDaddy>
<NodeADaddy>
<NodeA>
<NodeA/>
<NodeADaddy/>
<NodeAGrandDaddy/>
最佳答案
好吧,你可以使用 Select
方法和 ancestor-or-self::*
,即:
item.Select("ancestor-or-self::*")
关于c# - xPath 通过 XPathNavigator 对象而不是通过表达式求值查找祖先,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21690489/
这是我正在使用的 XML 示例(可从任何 wiki 的 Special:Export/SomePage 结果中检索): Wikipedia http://en.wikipedi
var xml= @" The Gorgias3
我有这样的 XML: 我正在尝试使用类似这样的方法在“c”标签上找到“val”属性的值: XmlDocument doc = new XmlDocument(); doc.
我有一个这样的 XML 文件: A 0.01 Pass A
给定以下 XML 标记: 和一个XPathNavigator位于 元素, string withNs = navigator.GetAttribute("name", navigator
我第一次使用 XPathNavigator 就从这里开始。 这是我的简单 xml: 现在,我正在使用 CommonLibrary.NET
我在使用 XPathNavigator 时遇到问题。我有一个文档,在流中包含一堆不带 namespace 的“主题”元素。 我正在使用(表达被简化到最低限度,首先我认为我的表达是错误的): XPath
我不想再问 XPath/XmlNamespaceManager 问题,但我似乎无法弄明白。 我使用了 XpathVisualizer 工具,它可以使用 XPath“//FuelGradeMovemen
我正在尝试查找某个节点的祖先。我们称它为“NodeA”。我得到了“NodeA”节点的列表,并想查找其祖先以检查某个属性值。这是我检索所有“NodeA”节点的代码: String xPathExpres
我怀疑我遗漏了一些基本但重要的东西,但正因为如此,我的 XPath 导航器总是返回根。 我有一些像这样的 XML 数据: about faqs feedback
这是我的代码,不知道为什么不能通过XPathNavigator读取数据。但在我添加命名空间和模式之前已经很久了。 XmlReaderSettings settings = ne
我正在寻找从 Microsoft 的 XPathNavigator 类派生的类的 C# 示例实现。任何人都可以指出这样一篇文章吗? 您可能知道(也可能不知道),XmlNavigator 旨在允许将 X
我有一个相当大的 XML 文件,我需要将其解析为 .NET 类结构(以映射到固定长度的记录格式并通过 MQ 传输)。性能很重要,但不是绝对关键。 我几乎总是使用 XPathNavigator 来读取
我有以下代码,其最后一行在每次执行时都会导致 NotSupportedException,而且我还没有找到绕过它的方法。这个假设的类似代码找到一本具有特定标题的“书”,目的是将其更新为新标题。它确实找
是否有一种简单的方法来检测 XPathNavigator XML 节点上是否存在 empty 属性(例如 与 )? Node.GetAttribute无论哪种方式都返回一个空字符串。我唯一能想到的就
这是使用 Microsoft 中的 XPathNavigator 的示例. using System; using System.Xml; using System.Xml.XPath; // htt
我尝试从 XmlNode(它是一个 XmlElement)获取行号,但它不能转换为 IXmlLineInfo。所以我尝试使用 XPathNavigator,但它也不起作用。 如何获取它的行号? 最佳答
我在 C# 中使用 XPathNavigator 计算值“89001012012341234”的模数不正确。 public object Evaluate(string expression) {
我看到了这个问题: XPathDocument vs. XmlDocument 但它没有我正在寻找的信息:我的问题: 我知道 XPathDocument 将完整 xml 加载到内存中: 我的问题来自
给定流作为输入,我如何针对 XML 数据源安全地创建 XPathNavigator? XML 数据源: 可能包含需要删除的无效十六进制字符。 可能包含与文档声明的编码不匹配的字符。 例如,云中的某些
我是一名优秀的程序员,十分优秀!