Rel*_*lla 30 c++ boost subtree boost-propertytree boost-foreach
首先,我要说我认为我应该怎么做但我的代码不会以任何方式编译我尝试.我的假设基于这个空ptree技巧的官方例子.在那里你可以找到下一行:
  const ptree &settings = pt.get_child("settings", empty_ptree<ptree>());
这表明从(或应该)可以从ptree中获取subptree.
所以我假设我们可以用BOOST_FOREACH这样的方式迭代到ptree :
BOOST_FOREACH(const boost::property_tree::ptree &v,
    config.get_child("servecies"))
{
}
但我得到下一个错误:
错误1错误C2440:'初始化':无法从'std :: pair <_Ty1,_Ty2>'转换为'const boost :: property_tree :: ptree&'
或者如果我尝试
BOOST_FOREACH(boost::property_tree::ptree &v,
    config.get_child("servecies", boost::property_tree::empty_ptree<boost::property_tree::ptree>()))
{
}
我明白了:
错误1错误C2039:'empty_ptree':不是'boost :: property_tree'的成员
那我该怎么做:如何通过Boost Ptree迭代并得到子Ptrees?
更新: 我也试过这样的代码
    BOOST_FOREACH(boost::property_tree::ptree::value_type &v,
    config.get_child("path.to.array_of_objects"))
{
    std::cout << "First data: " << v.first.data() << std::endl;
    boost::property_tree::ptree subtree = (boost::property_tree::ptree) v.second ;
    BOOST_FOREACH(boost::property_tree::ptree::value_type &vs,
        subtree)
    {
        std::cout << "Sub data: " << vs.first.data() << std::endl;
    }
}
这编译,不会抛出任何exeptions但不会cout任何Sub data,它只是通过这个循环斜倚.
更新2:
嗯...在我的xml中可能出错了 - 现在我用该代码得到了正确的结果.
ant*_*kos 32
属性树迭代器指向(key, tree)类型形式的对ptree::value_type.因此,迭代遍历节点子节点的标准循环path如下所示:
BOOST_FOREACH(const ptree::value_type &v, pt.get_child(path)) {
    // v.first is the name of the child.
    // v.second is the child tree.
}
Ela*_*782 26
使用C++ 11,您可以使用以下内容遍历节点的所有子节点path:
ptree children = pt.get_child(path);
for (const auto& kv : children) {
    // kv is of type ptree::value_type
    // kv.first is the name of the child
    // kv.second is the child tree
}
迭代通过JSON子节点我遇到了同样的问题
boost::property_tree::read_json(streamJSON, ptJSON);
如果你有一个像这样的结构:
{
 playlists: [ {
   id: "1",
   x: "something"
   shows: [
    { val: "test" },
    { val: "test1" },
    { val: "test2" }
   ]
 },
 {
   id: "2"
   x: "else",
   shows: [
    { val: "test3" }
   ]
 }
 ]
}
您可以像这样迭代子节点:
BOOST_FOREACH(boost::property_tree::ptree::value_type &playlist, ptJSON.get_child("playlists"))
{
    unsigned long uiPlaylistId = playlist.second.get<unsigned long>("id");
    BOOST_FOREACH(boost::property_tree::ptree::value_type &show, playlist.second.get_child("shows."))
    {
       std::string strVal = show.second.get<std::string>("val");
    }
}
我找不到关于路径选择器"show"的任何信息.选择子数组.(注意最后的点)
可以在这里找到一些好的文档:http: //kaalus.atspace.com/ptree/doc/index.html
希望这有助于某人.
| 归档时间: | 
 | 
| 查看次数: | 46974 次 | 
| 最近记录: |