c++ ptree判断是否存在节点_c++ Boost 1.46.1,属性树:如何迭代通过ptree接收子树?...

首先我会说,我想我应该怎么做,但我的代码不会编译任何方式,我尝试。我基于我的假设

this official example of empty ptree trick.在那里你可以找到下一行:

const ptree &settings = pt.get_child("settings", empty_ptree());

这表明它是(或应该)可能从ptree获得subptree。

所以我假设我们可以用像BOOST_FOREACH这样的方式遍历ptree:

BOOST_FOREACH(const boost::property_tree::ptree &v,

config.get_child("servecies"))

{

}

但我得到下一个错误:

Error 1 error C2440: ‘initializing’ : cannot convert from ‘std::pair<_ty1>’ to ‘const boost::property_tree::ptree &’

或如果我尝试

BOOST_FOREACH(boost::property_tree::ptree &v,

config.get_child("servecies", boost::property_tree::empty_ptree<:property_tree::ptree>()))

{

}

我得到:

Error 1 error C2039: ’empty_ptree’ : is not a member of ‘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任何子数据,它只是通过这个循环skeeps。

更新2:

Hm …一些可能在我的xml错误 – 现在我得到正确的结果与该代码。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值