我想从boost属性树中删除一个节点,但是我想保留它的子节点并将它们连接到已删除节点的父节点(即它们的祖父节点)。有没有一种优雅的方法来实现这一目标?
答案 0 :(得分:4)
这可能是让孙子孙女搬家的最有效方式:
std::move(middle.begin(), middle.end(), back_inserter(parent));
完整样本
<强> Live On Coliru 强>
#include <boost/property_tree/ptree.hpp>
#include <boost/property_tree/json_parser.hpp>
using boost::property_tree::ptree;
using boost::property_tree::read_json;
using boost::property_tree::write_json;
int main() {
std::istringstream iss(R"({ "a" : { "middle" : { "a1":1, "a2":2, "a3":3 }, "more":"stuff" } })");
ptree pt;
read_json(iss, pt);
auto& parent = pt.get_child("a");
auto& middle = pt.get_child("a.middle");
std::move(middle.begin(), middle.end(), back_inserter(parent));
parent.erase("middle");
write_json(std::cout, pt);
}
示例json输出:
{
"a": {
"more": "stuff",
"a1": "1",
"a2": "2",
"a3": "3"
}
}
答案 1 :(得分:0)
我必须做类似的事情。
我使用了一个带有递归的迭代器,并在删除节点并将其分支回新创建的节点之前复制了子节点。
但是我想在删除之前每棵树的完整副本都是非常耗费资源的,所以你只能用相对较小的树来做它并且它不是很优雅。