2016-03-26 53 views
0

所以我的XML作爲跟隨pugiXML找到孩子具有相同的父母看重

<level1> 
    <level2> 
      <hero1> 
      </hero1> 
    </level2> 
    <level2> 
      <hero2> 
      </hero2> 
    </level2> 
</level1> 

現在我要訪問hero2,但是當我做,想doc是我的XML數據

doc.child("level1").child("level2").child("hero2") 它返回false,這意味着它找不到我的hero2。我怎麼能找到它?

回答

1

讓我們考慮你的XML文件。當您撥打:

doc.child("level1").child("level2").child("hero2"); 

它等效於:

element1 = doc.child("level1").child("level2"); 
    element = element1.child("hero2"); 

讓我們來看看:

pugi::xml_node element1 = doc.child("level1").child("level2"); 
// Element 1 gives you first node "level2" 

// Element 2 does not have child ("hero2") so the call will return NULL 
pugi::xml_node element2 = element1.child("hero2"); // element2 is NULL 

// Element 2 has a child "hero1" 
// So you can get it as: 
pugi::xml_node element2child_hero1 = element1.child("hero1"); // 

但你想獲得 「HERO2」 而不是 「hero1」。

下面介紹了針對您的特定文件的解決方案之一。 for循環通過所有的兄弟姐妹去錢櫃「HERO2」發現:

int findHero2(const char *file) 
{ 
    pugi::xml_document doc; 
    if (!doc.load_file(file)) return -1; 

    pugi::xml_node level1 = doc.child("level1"); 

    for (pugi::xml_node level2 = level1.first_child(); level2; level2 = level2.next_sibling()) 
    { 
     pugi::xml_node node = level2.child("hero2"); 
     if(node!=NULL) 
     { 
      // I have found "hero2" node 
      // ... 
      return 0; // success 
     } 
    } 

    return -2; // no "hero2" 
} 
0

要在算法方面的回答:如果你(可能)有幾個孩子使用相同的名稱,迭代他們使用first_child(name)next_sibling(name)了。

相關問題