Эффективность парсинга php xml

Я новичок в 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>

Теперь, учитывая идентификатор задачи, мне нужно найти в 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, однако мне не удалось заставить его работать. Это работает, но я знаю, что это неэффективно. Любая помощь приветствуется, спасибо.

При каких предположениях вы считаете этот код неэффективным? Возможно, вы ищете код обмена стеками для гольфа.

castis 05.09.2018 20:54

Думал, что может быть лучший способ, чем использовать simplexml_load_file () и передать xml функции. У меня возникли проблемы с загрузкой всей страницы, и я подумал, что это может быть из-за размера xml.

T.Wolf 05.09.2018 21:07
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
1
2
29
1

Ответы 1

На данный момент это сработало для меня. Вместо того, чтобы передавать 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++;
    }
}

Другие вопросы по теме