首先我要说我认为我知道应该怎么做,但是我的代码不会以我尝试的任何方式编译。我的假设基于这个空 ptree 技巧的官方示例。在那里你可以找到下一行:
const ptree &settings = pt.get_child("settings", empty_ptree<ptree>());
这表明可以(或应该)从 ptree 中获取 subptree。
所以我假设我们可以通过 ptree 以BOOST_FOREACH
这样的方式迭代:
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 并获得子 Ptree?
更新: 我也试过这样的代码
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;
}
}
这会编译,不会抛出任何异常,但不会抛出任何Sub data
异常,它只是跳过这个循环。
更新 2:
嗯...我的 xml 中可能出了点问题 - 现在我使用该代码得到了正确的结果。