php ile xml belirli çocuğu düzenlemek için nasıl

3 Cevap php

Bu i php ile dinamik olarak düzenlemek istediğiniz xml çocuğudur

<items>
    	<item xVal="SMR012" yVal="3.76" ><![CDATA[<font color = "#000000">Rating: 3.76</font>]]></item>
    	<item xVal="SMR014" yVal="4.6" ><![CDATA[<font color = "#000000">Rating: 4.6</font>]]></item>
    	<item xVal="SMR015" yVal="2.56" ><![CDATA[<font color = "#000000">Rating : 2.56</font>]]></item>		
    </items>

ve burada bu çocuğu düzenlemek için veri almak php kodu

$query  = "SELECT * FROM `set`";
$result = MYSQL_QUERY($query);

while ($row = mysql_fetch_array ($result))
{
$query2  = "SELECT * FROM `release` WHERE label_id = '" . $row['ID'] . "'";
$result2 = MYSQL_QUERY($query2);
while ($info = mysql_fetch_array ($result2))
{

//here i got all the data, now i need to edit xml here

}
}

nasıl ben dinamik olarak bu çocuğu düzenleyebilirsiniz? (Ben de XVal ve yval atfettiği düzenlemeniz gerekir)

teşekkürler.

3 Cevap

Peki bu ne istediğiniz olup olmadığını bilmiyorum, ama bu xml satır yaratacak ve bundan sonra sadece $ xml ile madde ve / öğe arasındaki her şeyi yerine

$xml = '';


while ($info = mysql_fetch_array ($result2))
{

   $xml .= '<item xVal="'.$info['xVal'].'" yVal="'.$info['yVal'].'" >'.$info['data'].'</item>';

}

kullanmak yazmak için:

$handle = fopen('something.xml', 'w');  		
fwrite($handle, $xml);
fclose($handle);

Eğer o çocuk ürün bulunuyor bu öğeyi patlayabilir ve strpos ile kontrol etmek gerekir varolan xVal olup olmadığını ve kontrol etmek için

strpos($xml, 'xVal='.$info['xVal']);

if strpos returns something other than false (use === to check if it's false cause it can return 0), then you need to replace that whole row. It's a bit lenghty code.

DOMDocument ve xPath en iyi seçenek olacaktır. Bu ilk başta biraz karmaşık gibi görünüyor, ama çiğ xml dizeleri ile karıştırmasını daha uygun olur.

$xml = new DOMDocument();
$xml->load('test.xml');

$xPath = new DOMXPath($xml);
$result = $xPath->query("//item[@xVal='SMR014']");
$result->item(0)->nodeValue = 'New item value';
$result->item(0)->setAttribute('xVal', 'custom xVal');
echo $xml->saveXML();

Bu irade çıktı:

<?xml version="1.0"?>
<items>
        <item xVal="SMR012" yVal="3.76"><![CDATA[<font color = "#000000">Rating: 3.76</font>]]></item>
        <item xVal="custom xVal" yVal="4.6">New item value</item>
        <item xVal="SMR015" yVal="2.56"><![CDATA[<font color = "#000000">Rating : 2.56</font>]]></item>                
</items>