目前,如果我尝试解析
<parent>
First bit of text
<child>
</child>
Second bit of text
</parent>
我只First bit of text
和
parent.text().get()
获取所有文本节点的正确方法是parent
什么?
- 有一个很好的实用功能吗?
- 如何通过所有孩子进行迭代?
没有连接所有文本的函数;如果您想获取文本节点子节点的列表,您有两种选择:
XPath 查询:
pugi::xpath_node_set ns = parent.select_nodes("text()");
for (size_t i = 0; i < ns.size(); ++i)
std::cout << ns[i].node().value() << std::endl;
带类型检查的手动迭代:
for (pugi::xml_node child = parent.first_child(); child; child = child.next_sibling())
if (child.type() == pugi::node_pcdata)
std::cout << child.value() << std::endl;
请注意,如果您可以使用 C++11,那么第二个选项会更加简洁:
for (pugi::xml_node child: parent.children())
if (child.type() == pugi::node_pcdata)
std::cout << child.value() << std::endl;
(当然也可以使用ranged for来遍历xpath_node_set)
在我拥有的 pugixml 版本中,我可以使用 print 方法将所有内部 xml 从节点获取到流中。例如:
std::stringstream ss;
node.print(ss);
return ss.str();