XML解析- pugixml子节点数



pugixml节点对象是否有number-of-child-nodes方法?我在文档中找不到它,不得不使用迭代器,如下所示:

int n = 0;
for (pugi::xml_node ch_node = xMainNode.child("name"); ch_node; ch_node = ch_node.next_sibling("name")) n++;

没有内置函数可以直接计算;另一种方法是使用std::distance:

size_t n = std::distance(xMainNode.children("name").begin(), xMainNode.children("name").end());

当然,子节点的数量是线性的;请注意,计算所有子节点的数量std::distance(xMainNode.begin(), xMainNode.end())也是线性的——没有对子节点计数的恒定时间访问。

您可以使用基于xpath搜索的表达式(但不能保证效率):

xMainNode.select_nodes( "name" ).size()
int children_count(pugi::xml_node node)
{
  int n = 0;
  for (pugi::xml_node child : node.children()) n++;
  return n;
}

相关内容

  • 没有找到相关文章

最新更新