Php xml解析效率

问题描述 投票:-1回答:1

我是一个非常新的PHP,我知道这个代码拼凑起来工作或至少有这样的感觉,我知道还有改进的余地。我正在使用一个非常大的XML文件,我需要从文件中获取一个特定的值来填充表格中的一个块。 xml基本上是这样的。

<Project xmlns="http://schemas.microsoft.com/project">
  <Tasks>
   <Task>
   <UID>1234</UID>
   </Task>
  </Tasks>
  <Assignments>
   <Assignment>
    <TaskID>1234</TaskID>
    <ResourceID>1111</ResourceID>
   </Assignment>
  </Assignments>
  <Resources>
   <Resource>
    <UID>1111</UID>
    <Name>HELLO WORLD</UID>
   <Resource>
  </Resources>
 </Project>

现在给定任务ID我需要在XML中查找与该任务相关联的分配/分配并获取资源的名称。这个文件非常大,并且我只使用了一部分表加载的代码进行了很多赋值。这是我的PHP。

<?php
header("Cache-Control: no-cache, must-revalidate");
header("Expires: Sat, 26 Jul 1997 05:00:00 GMT");
date_default_timezone_set('America/Chicago');
$xml=simplexml_load_file("FILELOCATION.xml");
$xml->registerXPathNamespace('project', 'http://schemas.microsoft.com/project');
$tasks = $xml->Tasks;

function FindResource($strTaskID,$xml)
{

  $newPath = $xml->xpath("//project:Assignments/project:Assignment[project:TaskUID='$strTaskID']/project:ResourceUID");
 $resourceUID=(string)$newPath[0];
  if(!empty($resourceUID)&& (int)$resourceUID >0 )
  {
    $count =0;

   foreach ($newPath as $rUID)
   {
     if($count>0)
   {
         echo(", ");
    }
     $resource= $xml->xpath("//project:Resources/project:Resource[project:UID='$rUID']/project:Name");
     $resourceName = (string)$resource[0];

     echo($resourceName);
     $count++;
   }
  }
}

?>

我的html / php代码构建表

<body>
            <table>
                    <thead>
                            <tr>
                                    <td>Task</td>
                                    <td>Resource</td>
                                    <td>Days</td>
                                    <td>Start</td>
                                    <td>End</td>
                            </tr>
                    </thead>
                    <tbody>
<?php foreach ($tasks->Task as $value){ ?>
                    <tr>
                <td><span style="padding-left: <?php echo $value->OutlineLevel * 13; ?>px;"><?php echo $value->Name; ?></span></td>
                <td><?php echo FindResource($value->UID,$xml);?></td>
                <td class="duration"><?php echo FindDuration($value->Duration); ?></td>
                <td class="date"><?php echo OutputTime($value->Start);?></td>
                <td class="date"><?php echo OutputTime($value->Finish);?></td>
                    </tr>
<?php } ?>      </tbody>
                </table>

我已经尝试过使用xmlReader但是我无法让它工作。这有效,但我知道效率不高。任何帮助表示赞赏谢谢。

php xml
1个回答
0
投票

这对我来说现在很有用。我没有传入XML并使用xpath来获取我需要的元素,而是将XML分解成更小的部分并单独使用它们。这给了我一个想法,如果需要提前设置一个键/值对,因为分配将任务链接到资源。作为php新手,这比我预期的更快地加载我的网页。

function FindResource($strTaskID,$xml)
{
    $assignment = $xml->Assignments;
    $assignmentArray = array();
    $resource = $xml->Resources;
    foreach($assignment->Assignment as $ass)
    {

       if((int)$as->TaskUID == (int)$strTaskID)
       {
            if((int)$as->ResourceUID >0)
            {
               $assignmentArray[]=$as->ResourceUID;
            }
       }
    }
    $count =0;
    foreach ($assignmentArray as $rUID)
    {
        if($count >0)
            echo(", ");
        foreach ($resource->Resource as $value)
        {
           if((int)$value->UID == (int)$rUID)
           {
              echo($value->Name);
              break;
           }
        }
        $count++;
    }
}
© www.soinside.com 2019 - 2024. All rights reserved.