2011-03-04 89 views
0

我想创建一个XPath查询,该查询返回以下XML的“作业”为“Actor”,其“顺序”介于“0”和“4”之间的演员。我发现很难创建一个同时执行这两个操作的查询。与属性相关的XPath搜索

<cast> 
    <person name="David Silverman" character="" job="Director" order="0"/> 
    <person name="James L. Brooks" character="" job="Author" order="0"/> 
    <person name="Dan Castellaneta" character="Homer J. Simpson" job="Actor" order="0"/> 
    <person name="Julie Kavner" character="Marge Simpson" job="Actor" order="1"/> 
    <person name="Nancy Cartwright" character="Bart Simpson" job="Actor" order="2"/> 
    <person name="Yeardley Smith" character="Lisa Simpson" job="Actor" order="3"/> 
    <person name="Dan Castellaneta" character="Krusty the Clown" job="Actor" order="4"/> 
    <person name="Hank Azaria" character="Moe Szyslak" job="Actor" order="5"/> 
    <person name="Dan Castellaneta" character="Apu Nahasapeemapetilon" job="Actor" order="6"/> 
</cast> 

回答

3
cast/person[@job="Actor" and @order >= 0 and @order <= 3] 

返回你想要的四个Simpsons。

+0

谢谢我会试一试。 – RonanC 2011-03-04 09:21:45

+0

这工作很简单,我觉得很愚蠢。谢谢一堆。很好的帮助 – RonanC 2011-03-04 09:24:35

0

您可以使用//cast/person[@job='Actor' and position()<3]

+0

非常感谢您的及时响应。我知道使用@job来访问作业属性,但我想知道是否可以同时指定[@order> ='0'和@order <='4']的进一步约束条件时间在单个查询中指定[@job ='Actor'] – RonanC 2011-03-04 09:19:52

+0

@ user644347我是XPath新手,我注意到其他两个解决方案使用'order'而不是'position',这导致我相信我已经使用不太正确的解决方案。任何人向我解释?谢谢。 – alex 2011-03-04 09:33:33

0

您应该可以合并您的谓词//cast/person[@job='Actor' and @order>=0 and @order<=3]