2013-04-25 81 views
2

我有一些問題,使我的XML文件中的問題和答案元素的功能。我做了大量的研究學習PHP DOM,但我一直在堅持做這個功能。問題是,當我試圖通過屬性id獲取父元素行時,它返回null,或者當我使用xpath時,它返回一個空對象。我不知道在我得到正確的父元素後,該函數是否能正常工作,但這是我認爲的下一步。php xml dom getElementById和DOMXpath查詢失敗獲取元素

我的XML看起來是這樣的:

<?xml version="1.0" encoding="UTF-8"?> 
<root> 
    <row id="1"> 
    <question>Wat doet de vuilnisman?</question> 
    <answer>Hij tilt de vuilnisbak in de vuilnisauto.</answer> 
    </row> 
    <row id="2"> 
    <question>Wat zegt de tandarts vaak?</question> 
    <answer>U mag nu spoelen.</answer> 
    </row> 
</root> 

和我的PHP函數:

//modifies rows 
function modifyRows($file, $rowIds, $rowText) { 
    $xmlDoc = new DOMDocument(); 
    $xmlDoc->preserveWhiteSpace = false; 
    $xmlDoc->formatOutput = true; 
    $xmlDoc->load($file); 
    foreach($rowIds as $rowId) { 
     $parent = $xmlDoc->getElementById($rowId); 
     for($i=0;$i<count($rowText);$i++) { 
      $newQ = $xmlDoc->createElement('question'); 
      $qText = $xmlDoc->createTextNode($rowText[$i]); 
      $qText = $newQ->appendChild($qText); 
      $newA = $xmlDoc->createElement('answer'); 
      $aText = $xmlDoc->createTextNode($rowText[$i++]); 
      $aText = $newA->appendChild($aText); 
     } 
     $oldQ = $parent->getElementsByTagName('question'); 
     $oldA = $parent->getElementsByTagName('answer');   
     $parent->replaceChild($newQ, $oldQ); 
     $parent->replaceChild($newA, $oldA); 
    } 
    $xmlDoc->save($file); 
} 

$的rowid是其中包含的行數的數組,在修改過的ANS陣列rowText其中包含數組的問題和答案字符串(0 =>「question」,1 =>「answer」)等等。通過添加或刪除行,XML文件內容可以變得更大或更小。我已經爲此做了「工作」功能。

+0

而你的問題是? – hakre 2013-04-25 11:10:35

+0

如何通過屬性ID獲取此父元素,因爲這是我解釋的問題。 getElementById和通過id獲取元素的xpath查詢不會返回元素。 – Zeebats 2013-04-25 11:23:14

+0

如果已經xpath和getElementById沒有返回你想要獲取父項的元素,那麼你的問題應該是如何首先獲取元素本身* bevore *考慮獲取父項。這就是我問的原因。 Getelementbyid出了什麼問題?除非將ID設置爲不同的屬性名稱(對於您的示例XML而言,情況並非如此),該函數通常應該可以正常工作。 – hakre 2013-04-25 11:25:27

回答

10

我已經解決了問題thanx以及互聯網。所以對於有同樣問題的人來說,這就是我解決問題的方法。

function getElementById($id) { 
     $xpath = new DOMXPath($this->xmlDoc); 
     return $xpath->query("//*[@id='$id']")->item(0); 
    }