我想知道是否有一些方便的方法来使用路径方法访问列表的已知索引。
我的梦想方法
float v = pt.get<float>("root.list[0]);
目前已知的方法(或类似的方法)
ptree::value_type listElement;
BOOST_FOREACH(listElement,tree.get_child("root.list")){
return listElement.second.get<float>();
}
列表格式(json)
{
root:{
list:[1,2,3,4,5]
}
}
答案 0 :(得分:3)
您应该能够使用boost::property_tree::equal_range
访问列表中的元素范围。使用您正在使用的格式的JSON,没有与列表中的每个项目关联的名称元素。这意味着在访问范围中的子元素之前必须获取父节点。
以下代码是您可以调整的粗略示例:
输入Json文件(in.json):
{
"root" :
{
"list" : [1,2,3,4,5]
}
}
打印列表第n个元素的功能:
void display_list_elem( const ptree& pt, unsigned idx )
{
// note: the node elements have no name value, ergo we cannot get
// them directly, therefor we must access the parent node,
// and then get the children separately
// access the list node
BOOST_AUTO( listNode, pt.get_child("root.list") );
// get the children, i.e. the list elements
std::pair< ptree::const_assoc_iterator,
ptree::const_assoc_iterator > bounds = listNode.equal_range( "" );
std::cout << "Size of list : " << std::distance( bounds.first, bounds.second ) << "\n";
if ( idx > std::distance( bounds.first, bounds.second ) )
{
std::cerr << "ERROR Index too big\n";
return;
}
else
{
std::advance( bounds.first, idx );
std::cout << "Value @ idx[" << idx << "] = "
<< bounds.first->second.get_value<std::string>() << "\n";
}
std::cout << "Displaying bounds....\n";
display_ptree( bounds.first->second, 10 );
}