Создание и вывод массива в PHP из сложного XML-вывода - PullRequest
0 голосов
/ 29 сентября 2018

Я пытаюсь создать массив с некоторыми данными из этого вывода XML.Учитывая то, как данные структурированы, я обнаружил, что это довольно сложно.Я пытаюсь сформировать массив только с данными MECHANICAL description.Я бы хотел, чтобы мой вывод выглядел примерно так:

Mechanical Engine: 2.0L DOHC 4-Cylinder TFSI Transmission: 8-Speed Automatic w/Tirptronic Full-Time All-Wheel Drive и так далее ...

До сих пор я пытался назвать механические описания следующим образом:

<?php

$xml = file_get_contents('note.xml');
$dom = new DOMDocument();
$dom->loadXML($xml);

foreach ($dom->getElementsByTagName('standard') as $standard){
  $mechdescription = $standard->getElementsByTagName('description');
  $mecharray[] = $mechdescription;
}
foreach ($mecharray as $displaymech){
  echo $displaymech;
}

?>   

Вот фрагмент XML, из которого я пытаюсь извлечь:

    <VehicleDescription xmlns="urn:description7b.services.chrome.com" country="US" language="en" modelYear="2015" bestMakeName="Audi" bestModelName="A4" bestStyleName="4dr Sdn Auto quattro 2.0T Premium" bestTrimName="Premium">
      <standard>
        <header id="1236">MECHANICAL</header>
        <description>Engine: 2.0L DOHC 4-Cylinder TFSI -inc: Audi valvelift system</description>
        <category id="1048"/>
        <category id="1054"/>
        <category id="1213"/>
        <styleId>369101</styleId>
        <installed cause="BaseEquipment"/>
     </standard>
     <standard>
        <header id="1236">MECHANICAL</header>
        <description>Transmission: 8-Speed Automatic w/Tiptronic -inc: sport program and manual shift mode</description>
        <category id="1130"/>
        <category id="1195"/>
        <category id="1220"/>
        <styleId>369101</styleId>
        <installed cause="BaseEquipment"/>
     </standard>
     <standard>
        <header id="1236">MECHANICAL</header>
        <description>Full-Time All-Wheel Drive</description>
        <category id="1041"/>
        <styleId>369101</styleId>
        <installed cause="BaseEquipment"/>
     </standard>
     <standard>
        <header id="1236">MECHANICAL</header>
        <description>Engine Oil Cooler</description>
        <styleId>369101</styleId>
        <installed cause="BaseEquipment"/>
     </standard>
     <standard>
        <header id="1236">MECHANICAL</header>
        <description>80-Amp/Hr Maintenance-Free Battery w/Run Down Protection</description>
        <styleId>369101</styleId>
        <installed cause="BaseEquipment"/>
     </standard>
     <standard>
        <header id="1236">MECHANICAL</header>
        <description>150 Amp Alternator</description>
        <styleId>369101</styleId>
        <installed cause="BaseEquipment"/>
     </standard>
     <standard>
        <header id="1236">MECHANICAL</header>
        <description>Gas-Pressurized Shock Absorbers</description>
        <styleId>369101</styleId>
        <installed cause="BaseEquipment"/>
     </standard>
     <standard>
        <header id="1236">MECHANICAL</header>
        <description>Front And Rear Anti-Roll Bars</description>
        <styleId>369101</styleId>
        <installed cause="BaseEquipment"/>
     </standard>
     <standard>
        <header id="1236">MECHANICAL</header>
        <description>Electric Power-Assist Speed-Sensing Steering</description>
        <category id="1084"/>
        <styleId>369101</styleId>
        <installed cause="BaseEquipment"/>
     </standard>
     <standard>
        <header id="1236">MECHANICAL</header>
        <description>16.1 Gal. Fuel Tank</description>
        <styleId>369101</styleId>
        <installed cause="BaseEquipment"/>
     </standard>
     <standard>
        <header id="1236">MECHANICAL</header>
        <description>Single Stainless Steel Exhaust</description>
        <styleId>369101</styleId>
        <installed cause="BaseEquipment"/>
     </standard>
     <standard>
        <header id="1236">MECHANICAL</header>
        <description>Multi-Link Front Suspension w/Coil Springs</description>
        <styleId>369101</styleId>
        <installed cause="BaseEquipment"/>
     </standard>
     <standard>
        <header id="1236">MECHANICAL</header>
        <description>Multi-Link Rear Suspension w/Coil Springs</description>
        <styleId>369101</styleId>
        <installed cause="BaseEquipment"/>
     </standard>
     <standard>
        <header id="1236">MECHANICAL</header>
        <description>4-Wheel Disc Brakes w/4-Wheel ABS, Front Vented Discs, Brake Assist, Hill Hold Control and Electric Parking Brake</description>
        <category id="1018"/>
        <category id="1020"/>
        <category id="1228"/>
        <styleId>369101</styleId>
        <installed cause="BaseEquipment"/>
     </standard>
     <standard>
        <header id="1176">EXTERIOR</header>
        <description>Wheels: 8.0J x 17" 10-Spoke-Star-Design</description>
        <category id="1123"/>
        <styleId>369101</styleId>
     </standard>
     <standard>
        <header id="1176">EXTERIOR</header>
        <description>Tires: P245/45R17 AS</description>
        <category id="1092"/>
        <category id="1097"/>
        <styleId>369101</styleId>
     </standard>
     <standard>
        <header id="1176">EXTERIOR</header>
        <description>Wheels w/Silver Accents</description>
        <styleId>369101</styleId>
        <installed cause="BaseEquipment"/>
     </standard>
     <standard>
        <header id="1176">EXTERIOR</header>
        <description>Steel Spare Wheel</description>
        <styleId>369101</styleId>
        <installed cause="BaseEquipment"/>
     </standard>
     <standard>
        <header id="1176">EXTERIOR</header>
        <description>Compact Spare Tire Mounted Inside Under Cargo</description>
        <category id="1098"/>
        <styleId>369101</styleId>
        <installed cause="BaseEquipment"/>
     </standard>
     <standard>
        <header id="1176">EXTERIOR</header>
        <description>Clearcoat Paint</description>
        <styleId>369101</styleId>
        <installed cause="BaseEquipment"/>
     </standard>
     <standard>
        <header id="1176">EXTERIOR</header>
        <description>Express Open/Close Sliding And Tilting Glass 1st Row Sunroof w/Sunshade</description>
        <category id="1069"/>
        <category id="1132"/>
        <styleId>369101</styleId>
        <installed cause="BaseEquipment"/>
     </standard>
     <standard>
        <header id="1176">EXTERIOR</header>
        <description>Body-Colored Front Bumper</description>
        <styleId>369101</styleId>
        <installed cause="BaseEquipment"/>
     </standard>
     <standard>
        <header id="1176">EXTERIOR</header>
        <description>Body-Colored Rear Bumper</description>
        <styleId>369101</styleId>
        <installed cause="BaseEquipment"/>
     </standard>
     <standard>
        <header id="1176">EXTERIOR</header>
        <description>Rocker Panel Extensions</description>
        <styleId>369101</styleId>
        <installed cause="BaseEquipment"/>
     </standard>
     <standard>
        <header id="1176">EXTERIOR</header>
        <description>Aluminum Side Windows Trim and Black Front Windshield Trim</description>
        <styleId>369101</styleId>
        <installed cause="BaseEquipment"/>
     </standard>
 </VehicleDescription>

Любая помощь будет принята с благодарностью.

ОБНОВЛЕНИЕ 1
Я определил, как получить все description с для standard тегов.Тем не менее, я хочу только description для MECHANICAL данных.Вот мой текущий код, который следует моей прошлой логике.Могу ли я написать оператор IF вокруг этого?

foreach ($dom->getElementsByTagName('standard') as $standard){
  $mechdescription = $standard->getElementsByTagName('description')->item(0)->nodeValue;
  $mecharray[] = $mechdescription;
}
foreach ($mecharray as $displaymech){
  echo $displaymech."<br>";
}

UPDATE 2
@ splash58 предлагает использовать xPath - лучший способ решения этой проблемы.Под его руководством это мой текущий код.Я все еще не получаю никакого ответа.

<?php

 $xml = file_get_contents('note.xml');
 $dom = new DOMDocument();
 $dom->loadXML($xml);
 $xpath = new domXpath($dom);

 foreach ($xpath->query('//standard[header="MECHANICAL"]/description') as $mechdescription){
 $mecharray[] = $mechdescription->nodeValue ;
}
 foreach ($mecharray as $mechanicaldescription){
 echo $mechanicaldescription;
}

?>

Ответы [ 3 ]

0 голосов
/ 29 сентября 2018

Я обнаружил, что в следующем списке перечислены все описания в стандартных тегах.Все еще пытаюсь понять, как вызвать тех, у кого есть только заголовок MECHANICAL.

foreach ($dom->getElementsByTagName('standard') as $standard){
  $mechdescription = $standard->getElementsByTagName('description')->item(0)->nodeValue;
  $mecharray[] = $mechdescription;

}

foreach ($mecharray as $displaymech){
  echo $displaymech."<br>";
}
0 голосов
/ 29 сентября 2018

Вы можете использовать xpath для выбора узла с вашим условием

$dom = simplexml_load_string($xml);
foreach ($dom->xpath('//standard[header="MECHANICAL"]/description') as $mechdescription){
   $mecharray[] = $mechdescription;
}

ОБНОВЛЕНИЕ

Если вы хотите использовать domDocument

$dom = new DOMDocument(); 
$dom->loadXML($xml);
$xpath = new domXpath($dom);

foreach ($xpath->query('//standard[header="MECHANICAL"]/description') as $mechdescription){
  $mecharray[] = $mechdescription->nodeValue ;
}
0 голосов
/ 29 сентября 2018

Что вы должны попытаться сделать, это сначала преобразовать заданную XML-строку в XML в JSON , а затем преобразовать ее в Array .

$pureXml = simplexml_load_string($strXml, "SimpleXMLElement", LIBXML_NOCDATA);
$json = json_encode($pureXml);
$arr = json_decode($json,TRUE);
foreach($arr as $subArr){
   if($subArr['header'] == 'MECHANICAL'){
       print $subArr['header] . "<br>" . $subArr['description'];
   }
}
...