boost propertytree

boost propertytree

本文关键字:propertytree boost      更新时间:2023-10-16

根据这里的boost文档:

http://www.boost.org/doc/libs/1_41_0/doc/html/boost_propertytree/container.html

"在一个节点中可能有多个具有相同键值的子节点。然而,这些孩子不一定是顺序的。find返回的迭代器可以引用其中的任何一个,并且不能保证其他同名子节点的相对位置。"

示例XML:

<library>
   <book><title>Title_1</title></book>
   <book><title>Title_2</title></book>
   <book><title>Title_3</title></book>
</library>

示例boost代码:

ptree pt;
pt.push_back(ptree::value_type("book", ptree("title")))
// This finds the first book and cannot iterate to the second one:
ptree::const_iterator it = pt.find("book");

既然知道了这些,你怎么能得到所有的书,并确保你把它们都读了呢?

您必须使用equal_range函数:

std::pair < ptree::const_assoc_iterator, ptree::const_assoc_iterator> bounds = 
    pt.equal_range("book");
for (ptree::const_assoc_iterator it = bounds.first; it != bounds.second ; ++it)
{
    // process *it
}