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






На данный момент это сработало для меня. Вместо того, чтобы передавать 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++;
}
}
При каких предположениях вы считаете этот код неэффективным? Возможно, вы ищете код обмена стеками для гольфа.