在xpath中选择多个条件

时间:2013-06-30 17:05:49

标签: php xpath

我正在尝试使用来自高尔夫锦标赛的xml Feed,以便在高尔夫球场上显示每个高尔夫球手的位置。我目前想要展示符合两个标准的每个高尔夫球手(排名前25位,所有高尔夫球手都是加拿大人)。

以下是xml Feed的示例。

<GolfDataFeed Type="Leaderboards" Timestamp="3/21/2012 9:18:09 PM">
<Tournament ID="27828" Name="WEGMANS LPGA CHAMPIONSHIP">
<Leaderboard RoundID="4" CutRound="" CutLine="">
<Player ID="82866" WwgrID="975" FirstName="Inbee" LastName="Park" Country="KOR" IsAmateur="False" Rank="1" RankTied="False" StartRank="1" StartRankTied="False" Thru="0" StartTee="1" StartTime="01:25 PM" RoundToPar="0" CumulativeTotal="206" CumulativeToPar="-10" Money="0" TournamentStatus="ACT" RoundStatus="ACT">
<Player ID="82850" WwgrID="434" FirstName="I.K." LastName="Kim" Country="KOR" IsAmateur="False" Rank="2" RankTied="False" StartRank="2" StartRankTied="False" Thru="0" StartTee="1" StartTime="01:25 PM" RoundToPar="0" CumulativeTotal="210" CumulativeToPar="-6" Money="0" TournamentStatus="ACT" RoundStatus="ACT">
<Player ID="88290" WwgrID="3336" FirstName="Jodi" LastName="Ewart Shadoff" Country="ENG" IsAmateur="False" Rank="3" RankTied="False" StartRank="3" StartRankTied="False" Thru="0" StartTee="1" StartTime="01:14 PM" RoundToPar="0" CumulativeTotal="213" CumulativeToPar="-3" Money="0" TournamentStatus="ACT" RoundStatus="ACT">
<Player ID="98006" WwgrID="2982" FirstName="So Yeon" LastName="Ryu" Country="KOR" IsAmateur="False" Rank="4" RankTied="True" StartRank="4" StartRankTied="True" Thru="0" StartTee="1" StartTime="01:14 PM" RoundToPar="0" CumulativeTotal="215" CumulativeToPar="-1" Money="0" TournamentStatus="ACT" RoundStatus="ACT">
</Leaderboard>
</Tournament>
</GolfDataFeed>

这是我编写的代码,用于选择加拿大或前25名

的所有高尔夫球手
$context = stream_context_create(array('http' => array('header' => 'Accept: application/xml')));
$url = 'http://services.lpgascoring.com/ws/1.2/leaderboard;
$xml = file_get_contents($url, false, $context);
$xml = simplexml_load_string($xml);

foreach($xml->xpath("///Player[@Rank<'25' or @Country='CAN']") as $Player)

我尝试添加额外的行来按其LastName选择玩家,但这似乎不起作用。

foreach($xml->xpath("///Player[@Rank<'25' or @Country='CAN' or @LastName='Wie' or @LastName='Peterson']") as $Player)

有没有人知道如何在xpath查询中包含更多的条件语句?

提前致谢, 麦克

1 个答案:

答案 0 :(得分:0)

你的XPath中有太多的正斜杠。请尝试使用此XPath:

//Player[@Rank<'25' or @Country='CAN']