2016-03-26 51 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)了。

相关问题