有没有一种方便的方法从属性树中删除节点,保留其子节点?

时间:2015-04-10 12:46:32

标签: c++ xml boost boost-propertytree

我想从boost属性树中删除一个节点,但是我想保留它的子节点并将它们连接到已删除节点的父节点(即它们的祖父节点)。有没有一种优雅的方法来实现这一目标?

2 个答案:

答案 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)

我必须做类似的事情。

我使用了一个带有递归的迭代器,并在删除节点并将其分支回新创建的节点之前复制了子节点。

但是我想在删除之前每棵树的完整副本都是非常耗费资源的,所以你只能用相对较小的树来做它并且它不是很优雅。