使用以下C ++代码,使用RapidXml库,我只能在顶级获取XML元素,而不是子级:
char *text = ... // XML file shown below
using namespace rapidxml;
xml_document<> doc;
doc.parse<0>(text);
xml_node<> *node = doc.first_node();
while(node != 0) {
cout << node->name() << " " << node->value() << endl;
node = node->next_sibling(); // <-- ???
}
XML文件:
<parent>
<child>123</child>
</parent>
<parent>
<child>456</child>
</parent>
实际结果:
parent
parent
预期结果:
parent
child 123
parent
child 456
我怎样才能让孩子们接受?
谢谢!
答案 0 :(得分:2)
第二个parent
是第一个兄弟姐妹(“兄弟姐妹”处于同一水平 - 就像现实生活中的兄弟姐妹一样)。
node->first_node()
将成为node
的第一个孩子。
以下(未编译和未经测试)代码应生成您所需的输出:
xml_node<> *node = doc.first_node();
while(node != 0) {
cout << node->name() << endl;
xml_node<> *child = node->first_node();
while (child != 0)
{
cout << child->name() << " " << child->value() << endl;
child = child->next_sibling();
}
node = node->next_sibling();
}
答案 1 :(得分:2)
首先,您可以将XML数据保存到文件,例如“1.xml”
<parent>
<child>123</child>
</parent>
<parent>
<child>456</child>
</parent>
然后我认为你可以这样做:
void Parse(std::string strFilePath)
{
rapidxml::file<> docFile(strFilePath.c_str());
rapidxml::xml_document<> doc;
doc.parse<0>(docFile.data());
rapidxml::xml_node<> *pNode = doc.first_node();
for (; pNode != NULL; pNode = pNode->next_sibling())
{
std::cout << pNode->name() << std::endl;
for (rapidxml::xml_node<> *pChildNode = pNode->first_node(); pChildNode != NULL; pChildNode = pChildNode->next_sibling())
{
std::cout << " " << pChildNode->name() << " " << pChildNode->value() << std::endl;
}
}
}