使用PHP从XML表中提取NHL排名

时间:2014-11-26 23:24:50

标签: php mysql arrays xml parsing

我正在开展一个项目,在该项目中我提取有关NHL的各种统计信息并将它们插入到SQL表中。目前,我正在进行抓取阶段,并且已经找到了我已经实现的XML解析器,但我不能在我的生活中找出如何从中获取信息。该表格可以在这里找到 - > http://www.tsn.ca/datafiles/XML/NHL/standings.xml。 据说解析器生成一个多维数组,我只是试图从" info-teams"中提取所有数据。部分,但我不知道如何从数组中提取信息。我将如何利用蒙特利尔的胜利数量? (仅作为其余统计数据的一个例子) 这就是页面目前的样子 - > http://mattegener.me/school/standings.php 这是代码:

<?php
$strYourXML = "http://www.tsn.ca/datafiles/XML/NHL/standings.xml";
$fh = fopen($strYourXML, 'r');
$dummy = fgets($fh);
$contents = '';
while ($line = fgets($fh)) $contents.=$line;
 fclose($fh);
$objXML = new xml2Array();
$arrOutput = $objXML->parse($contents);
print_r($arrOutput[0]); //This print outs the array.

class xml2Array {

var $arrOutput = array();
var $resParser;
var $strXmlData;

function parse($strInputXML) {

        $this->resParser = xml_parser_create ();
        xml_set_object($this->resParser,$this);
        xml_set_element_handler($this->resParser, "tagOpen", "tagClosed");

        xml_set_character_data_handler($this->resParser, "tagData");

        $this->strXmlData = xml_parse($this->resParser,$strInputXML );
        if(!$this->strXmlData) {
           die(sprintf("XML error: %s at line %d",
        xml_error_string(xml_get_error_code($this->resParser)),
        xml_get_current_line_number($this->resParser)));
        }

        xml_parser_free($this->resParser);

        return $this->arrOutput;
}
function tagOpen($parser, $name, $attrs) {
   $tag=array("name"=>$name,"attrs"=>$attrs); 
   array_push($this->arrOutput,$tag);
}

function tagData($parser, $tagData) {
   if(trim($tagData)) {
        if(isset($this->arrOutput[count($this->arrOutput)-1]['tagData'])) {
            $this->arrOutput[count($this->arrOutput)-1]['tagData'] .= $tagData;
        } 
        else {
            $this->arrOutput[count($this->arrOutput)-1]['tagData'] = $tagData;
        }
   }
}

function tagClosed($parser, $name) {
   $this->arrOutput[count($this->arrOutput)-2]['children'][] = $this->arrOutput[count($this-      >arrOutput)-1];
   array_pop($this->arrOutput);
}
}


 ?>

2 个答案:

答案 0 :(得分:1)

将此搜索功能添加到您的班级并使用此代码

$objXML = new xml2Array();
$arrOutput = $objXML->parse($contents);
//  first param is always 0
//  second is 'children' unless you need info like last updated date
//  third is which statistics category you want for example
// 6 => the array you want that has wins and losses
print_r($arrOutput[0]['children'][6]);
//using the search function if key NAME is Montreal in the whole array 
//result will be montreals array
$search_result = $objXML->search($arrOutput, 'NAME', 'Montreal');
//first param is always 0
//second is key name
echo $search_result[0]['WINS'];

function search($array, $key, $value)
{
    $results = array();

    if (is_array($array))
    {
        if (isset($array[$key]) && $array[$key] == $value)
            $results[] = $array;

        foreach ($array as $subarray)
            $results = array_merge($results, $this->search($subarray, $key, $value));
    }

    return $results;
} 

<强>当心
 此搜索功能区分大小写需要修改,如匹配 将蒙特利尔中的大写字母M改为小写的键或值的百分比为空

答案 1 :(得分:1)

以下是我发送给您的代码。从您正在使用的同一链接中提取数据

http://sjsharktank.com/standings.php

我实际上已将相同的 XML 文件用于我自己的学校项目。我使用 DOM 文档。 foreach循环将获得团队支持的每个属性的值并存储值。代码将清除表排名的内容,然后重新插入数据。我想你可以做一个更新语句,但这假设你从未在表中输入任何数据。

 try {   
      $db = new PDO('sqlite:../../SharksDB/SharksDB');  
      $db->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);  
    } catch (Exception $e) {  
       echo "Error: Could not connect to database.  Please try again later.";
       exit;
    }   
            $query = "DELETE FROM standings";
            $result = $db->query($query);

            $xmlDoc = new DOMDocument();
            $xmlDoc->load('http://www.tsn.ca/datafiles/XML/NHL/standings.xml');
            $searchNode = $xmlDoc->getElementsByTagName( "team-standing" ); 
            foreach ($searchNode as $searchNode) {
                $teamID = $searchNode->getAttribute('id');
                $name = $searchNode->getAttribute('name');
                $wins = $searchNode->getAttribute('wins');
                $losses = $searchNode->getAttribute('losses');
                $ot = $searchNode->getAttribute('overtime');
                $points = $searchNode->getAttribute('points');
                $goalsFor = $searchNode->getAttribute('goalsFor');
                $goalsAgainst = $searchNode->getAttribute('goalsAgainst');
                $confID = $searchNode->getAttribute('conf-id');
                $divID = $searchNode->getAttribute('division-id');

                $query = "INSERT INTO standings ('teamid','confid','divid','name','wins','losses','otl','pts','gf','ga')
                          VALUES ('$teamID','$confID','$divID','$name','$wins','$losses','$ot','$points','$goalsFor','$goalsAgainst')";
                $result= $db->query($query);
            }