Извлечение данных XML с помощью DOMDocument на основе идентификаторов - PullRequest
0 голосов
/ 02 октября 2018

Я извлекаю данные из XML-документа, используя циклы DOMDocument и foreach.Данные от VIN-декодера.Введите VIN транспортного средства, и в ответ вы получите данные об этом.

Аспект, с которым я борюсь, заключается в том, что декодер VIN возвращает данные о транспортном средстве, которое сегментировано по стилю этого транспортного средства.Например, VIN для Audi S4 возвращает два стиля: 5dr Avant Wgn Man и 5dr Avant Wgn Auto.Каждый стиль имеет идентификатор, и данные, которые применяются к этому стилю, также содержат этот идентификатор.

Вот структура идентификаторов для этих двух стилей:
5dr Avant Wgn Man - ID: 292015
5dr Avant Wgn Auto - ID: 292016

И пример того, как данные связаны с этими идентификаторами:

    <technicalSpecification>
        <titleId>2</titleId>
        <value value="5 Door Wagon" condition="">
           <styleId>292015</styleId>
           <styleId>292016</styleId>
        </value>
     </technicalSpecification>

Обратите внимание, что 5 Door Wagon применяется к обоим стилям.

Чего я хочу добиться - это при выборе 5dr Avant Wgn Man все данные <technicalSpecification>, связанные с этим стилем, будут отображаться.Точно так же, если выбран 5dr Avant Wgn Auto, будут отображены все данные, связанные с этим стилем.

Это XML:

<S:Envelope xmlns:S="http://schemas.xmlsoap.org/soap/envelope/">
 <S:Body>
  <VehicleDescription country="US" language="en" modelYear="2008" bestMakeName="Audi" bestModelName="S4" bestStyleName="5dr Avant Wgn" xmlns="urn:description7b.services.chrome.com">
     <responseStatus responseCode="Successful" description="Successful"/>

     <style id="292015" modelYear="2008" name="5dr Avant Wgn Man" nameWoTrim="5dr Avant Wgn Man" mfrModelCode="8ED549" fleetOnly="false" modelFleet="false" passDoors="4" altBodyType="Station Wagon" drivetrain="All Wheel Drive">
        <division id="4">Audi</division>
        <subdivision id="5020">Audi</subdivision>
        <model id="17308">S4</model>
        <basePrice unknown="false" invoice="46137.0" msrp="49610.0" destination="775.0"/>
        <bodyType primary="true" id="7">Station Wagon</bodyType>
        <marketClass id="53">Small Wagon</marketClass>
        <acode>USB80AUC085A0</acode>
     </style>
     <style id="292016" modelYear="2008" name="5dr Avant Wgn Auto" nameWoTrim="5dr Avant Wgn Auto" mfrModelCode="8ED54L" fleetOnly="false" modelFleet="false" passDoors="4" altBodyType="Station Wagon" drivetrain="All Wheel Drive">
        <division id="4">Audi</division>
        <subdivision id="5020">Audi</subdivision>
        <model id="17308">S4</model>
        <basePrice unknown="false" invoice="47162.0" msrp="50710.0" destination="775.0"/>
        <bodyType primary="true" id="7">Station Wagon</bodyType>
        <marketClass id="53">Small Wagon</marketClass>
        <acode>USB80AUC085A1</acode>
     </style>
     <technicalSpecification>
        <titleId>1</titleId>
        <value value="Audi S4" condition="-PT">
           <styleId>292015</styleId>
           <styleId>292016</styleId>
        </value>
        <value value="Audi S4" condition="">
           <styleId>292015</styleId>
           <styleId>292016</styleId>
        </value>
     </technicalSpecification>
     <technicalSpecification>
        <titleId>2</titleId>
        <value value="5 Door Wagon" condition="">
           <styleId>292015</styleId>
           <styleId>292016</styleId>
        </value>
     </technicalSpecification>
     <technicalSpecification>
        <titleId>6</titleId>
        <value value="All-Wheel Drive" condition="">
           <styleId>292015</styleId>
           <styleId>292016</styleId>
        </value>
     </technicalSpecification>
     <technicalSpecification>
        <titleId>7</titleId>
        <value value="Small Station Wagon" condition="">
           <styleId>292015</styleId>
           <styleId>292016</styleId>
        </value>
     </technicalSpecification>
     <technicalSpecification>
        <titleId>8</titleId>
        <range min="5.0" max="5.0"/>
        <value value="5" condition="">
           <styleId>292015</styleId>
           <styleId>292016</styleId>
        </value>
     </technicalSpecification>
     <technicalSpecification>
        <titleId>9</titleId>
        <range min="90.8" max="90.8"/>
        <value value="90.8" condition="">
           <styleId>292015</styleId>
           <styleId>292016</styleId>
        </value>
     </technicalSpecification>
     <technicalSpecification>
        <titleId>10</titleId>
        <range min="4012.0" max="4101.0"/>
        <value value="4012" condition="">
           <styleId>292015</styleId>
        </value>
        <value value="4101" condition="">
           <styleId>292016</styleId>
        </value>
     </technicalSpecification>
     <technicalSpecification>
        <titleId>26</titleId>
        <range min="13.0" max="14.0"/>
        <value value="13" condition="">
           <styleId>292015</styleId>
        </value>
        <value value="14" condition="">
           <styleId>292016</styleId>
        </value>
     </technicalSpecification>
     <technicalSpecification>
        <titleId>27</titleId>
        <range min="20.0" max="21.0"/>
        <value value="20" condition="">
           <styleId>292015</styleId>
        </value>
        <value value="21" condition="">
           <styleId>292016</styleId>
        </value>
     </technicalSpecification>
     <technicalSpecification>
        <titleId>31</titleId>
        <value value="- TBD -" condition="">
           <styleId>292015</styleId>
           <styleId>292016</styleId>
        </value>
     </technicalSpecification>
     <technicalSpecification>
        <titleId>32</titleId>
        <value value="- TBD -" condition="">
           <styleId>292015</styleId>
           <styleId>292016</styleId>
        </value>
     </technicalSpecification>
     <technicalSpecification>
        <titleId>33</titleId>
        <value value="- TBD -" condition="">
           <styleId>292015</styleId>
           <styleId>292016</styleId>
        </value>
     </technicalSpecification>
     <technicalSpecification>
        <titleId>34</titleId>
        <value value="- TBD -" condition="">
           <styleId>292015</styleId>
           <styleId>292016</styleId>
        </value>
     </technicalSpecification>
     <technicalSpecification>
        <titleId>40</titleId>
        <value value="" condition="">
           <styleId>292015</styleId>
           <styleId>292016</styleId>
        </value>
     </technicalSpecification>
     <technicalSpecification>
        <titleId>41</titleId>
        <value value="Gas V8" condition="">
           <styleId>292015</styleId>
           <styleId>292016</styleId>
        </value>
     </technicalSpecification>
     <technicalSpecification>
        <titleId>42</titleId>
        <value value="4.2L/254" condition="">
           <styleId>292015</styleId>
           <styleId>292016</styleId>
        </value>
     </technicalSpecification>
     <technicalSpecification>
        <titleId>43</titleId>
        <value value="SEFI" condition="">
           <styleId>292015</styleId>
           <styleId>292016</styleId>
        </value>
     </technicalSpecification>
     <technicalSpecification>
        <titleId>48</titleId>
        <value value="340 @ 6800" condition="">
           <styleId>292016</styleId>
        </value>
        <value value="340 @ 7000" condition="">
           <styleId>292015</styleId>
        </value>
     </technicalSpecification>
     <technicalSpecification>
        <titleId>49</titleId>
        <value value="302 @ 3500" condition="">
           <styleId>292015</styleId>
           <styleId>292016</styleId>
        </value>
     </technicalSpecification>
     <technicalSpecification>
        <titleId>51</titleId>
        <value value="" condition="">
           <styleId>292015</styleId>
           <styleId>292016</styleId>
        </value>
     </technicalSpecification>
     <technicalSpecification>
        <titleId>52</titleId>
        <range min="6.0" max="6.0"/>
        <value value="6" condition="">
           <styleId>292015</styleId>
           <styleId>292016</styleId>
        </value>
     </technicalSpecification>
     <technicalSpecification>
        <titleId>53</titleId>
        <value value="Manual" condition="">
           <styleId>292015</styleId>
        </value>
        <value value="Automatic" condition="">
           <styleId>292016</styleId>
        </value>
     </technicalSpecification>
     <technicalSpecification>
        <titleId>54</titleId>
        <value value="" condition="">
           <styleId>292015</styleId>
           <styleId>292016</styleId>
        </value>
     </technicalSpecification>
     <technicalSpecification>
        <titleId>56</titleId>
        <range min="3.67" max="4.17"/>
        <value value="3.67" condition="">
           <styleId>292015</styleId>
        </value>
        <value value="4.17" condition="">
           <styleId>292016</styleId>
        </value>
     </technicalSpecification>
     <technicalSpecification>
        <titleId>57</titleId>
        <range min="2.05" max="2.34"/>
        <value value="2.05" condition="">
           <styleId>292015</styleId>
        </value>
        <value value="2.34" condition="">
           <styleId>292016</styleId>
        </value>
     </technicalSpecification>
     <technicalSpecification>
        <titleId>58</titleId>
        <range min="1.46" max="1.52"/>
        <value value="1.46" condition="">
           <styleId>292015</styleId>
        </value>
        <value value="1.52" condition="">
           <styleId>292016</styleId>
        </value>
     </technicalSpecification>
     <technicalSpecification>
        <titleId>59</titleId>
        <range min="1.13" max="1.14"/>
        <value value="1.13" condition="">
           <styleId>292015</styleId>
        </value>
        <value value="1.14" condition="">
           <styleId>292016</styleId>
        </value>
     </technicalSpecification>
  </VehicleDescription>

И мой PHP.Этот PHP помещает два типа стилей в выпадающий список и печатает <technicalSpecification>.Мне просто нужно, чтобы <techhnicalSpecification> изменилось в зависимости от того, какой style выбран в раскрывающемся списке.

<html>
 <body>

  <?php

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

  ?>

  <form>
   <select>
    <option selected="selected">Choose style</option>
   <?php
    foreach ($dom->getElementsByTagName('style') as $styleName){
      $styleType = $styleName->getAttribute("name");
      $styleArray[] = $styleType;
     }
    foreach ($styleArray as $style){
     ?>
     <option><?php echo $style;?> </option>
    <?php
     }
    ?>
    </select>
   </form>

   <br>

    <?php

    foreach ( $dom->getElementsByTagName('technicalSpecification') as $techSpec )   {
    $id = $techSpec->getElementsByTagName('titleId')->item(0)->nodeValue;
    $techData [$id]= $techSpec->getElementsByTagName('value')->item(0)->getAttribute("value")."<br>";
     }

    echo "<br><br>";
    print_r($techData);
   ?>

  </body>
 </html>

Большое спасибо!За вашу помощь!

1 Ответ

0 голосов
/ 02 октября 2018

Это SOAP (не только XML), поэтому вы должны попытаться использовать библиотеку PHP SOAP.Однако, если вам нравится анализировать его как обычный XML, взгляните на DOMXpath::evaluate().Это позволяет использовать выражения Xpath для выборки узлов (например, SQL, но для XML DOM).Вы можете выбрать узлы элементов на основе значений атрибутов:

$xpath = new DOMXpath($document);
foreach ($xpath->evaluate('//technicalSpecification[value/@value="5dr Avant Wgn Man"]') as $specNode) {
   ...
}
...