2

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

这是 xml 提要的示例。

<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)

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

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

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

在此先感谢,迈克

4

1 回答 1

0

您的 XPath 中有太多正斜杠。试试这个 XPath:

//Player[@Rank<'25' or @Country='CAN']
于 2013-06-30T23:34:39.410 回答