我试图找到特定节点A xor的所有直接子节点当且仅当B作为A的子代存在时-- B的直接子节点。我被困住了!
(A和B表示特定元素,例如<body/>和<article/>)
另一种方式是:
如果某个元素B是A的子元素,则查找B的子元素,而不是A。否则,只返回A的子级。
或者,还有另一种方式:
A > c c c c c c...
A > B > c c c c c c...我想得到[c, c, c, c, c, c, ...],不管B是否存在。如果DOM中出现了上述级别,我基本上希望“跳过一个级别”。请建议一种方法。
谢谢。
发布于 2015-01-09 04:49:02
首先,两个与XPath 1.0兼容的示例:
你可以这样做:
(/parent/container/a[not(b)] | /parent/container/a/b)/*或者使用双斜杠语法(除非路径非常长,否则我建议避免这种语法):
(//a[not(b)] | //a/b)/*但是,由于您的问题被标记为XPath 2.0,下面的问题可能比这两种问题都更有效:
/parent/container/a/(if (b) then b/* else *)示例输入:
<parent>
<container>
<a>
<c>1</c>
<c>2</c>
</a>
</container>
<container>
<a>
<c>3</c>
<b>
<c>4</c>
<c>5</c>
</b>
<b>
<c>6</c>
</b>
<c>7</c>
</a>
</container>
<container>
<a>
<c>8</c>
</a>
</container>
</parent>当使用上述任何路径运行时,结果是:
<c>1</c>
<c>2</c>
<c>4</c>
<c>5</c>
<c>6</c>
<c>8</c>发布于 2015-01-09 04:18:37
//a[not(child::b)]/child::* | //b[parent::a]/child::*https://stackoverflow.com/questions/27853539
复制相似问题