QTreeWidget遍历所有子节点以及删除整个TreeWidget

1. QTreeWidget删除整个TreeWidget

使用递归方式来删除节点下的子节点。分析:如果当前节点没有子节点那么就直接删除,如果有子节点就进入子节点继续删除(这里采用递归形式)直到最低层的节点(没有子节点)返回。然后逐一一层一层的返回实现递归删除。

说明:这里利用了第一个节点删除后下一个节点自动的会成为第一个节点特性。循环删除第一个节点从而实现删除所有节点的目的。

//递归删除节点
void MainWindow::removeItem(QTreeWidgetItem *item)
{
    int count = item->childCount();
    if(count == 0)//没有子节点,直接删除
    {
        delete item;
        return;
    }

    for(int i=0; i<count; i++)
    {
        QTreeWidgetItem *childItem = item->child(0);//删除子节点
        removeItem(childItem);
    }
    delete item;//最后将自己删除

}

/**
 * @brief MainWindow::removeAll_treeWidgetItemv
 * 功能:删除QTreeWidget中所有节点
 */
void MainWindow::removeAll_treeWidgetItemv(void)
{
    //通过删除根节点及其子节点来达到删除整个TreeWidget的目的
    QTreeWidgetItem *item;
    item = ui->josn_treeWidget->topLevelItem(0);
    while(item)
    {
         removeItem(item);
         item = ui->josn_treeWidget->topLevelItem(0);
    }
}

2. QTreeWidget遍历当前节点的所有子节点

说明:这里使用了QTreeWidget迭代器遍历整个TreeWidget控件,然后再判断具有相同父节点的节点。如果节点的父节点(一直往上找,可能是父节点的父节点)相同表示是同一个父节点下的子节点(不一定是同一级的节点)。

/**
  * 功能:查找当前节点下所有子节点
  * 返回值:返回
  **/
int myjosn_string::FindALL_childrenNode(QTreeWidgetItem *item)
{
    if(item->childCount() == 0) //说明:当Item下没有子节点时会导致程序崩溃
    {
        return 0;
    }
    //使用QTreeWidgetItem迭代器从当前节点遍历整个QTreeWidget树
    //判断条件:判断每个QTreeWidgetItem的parent是不是当前节点,如果是表示当前遍历的节点为此节点的子节点
    //否则就不是则停止遍历。此处已经是当前节点的最后一个子节点了
    QTreeWidgetItemIterator ite_item(item); //迭代器的参数应该为全局变量才行
    int all_children_count = 0;
    //节点没有父节点时,返回NULL
    QTreeWidgetItem *temp_item;
    ite_item++;
    temp_item = (*ite_item)->parent();

    qDebug() << "当前节点" << item->childCount();

    if(item->childCount() != 0)
    {
        while((*ite_item))
        {
            while(temp_item)	//筛选具有相同父节点的节点
            {
                if(temp_item != item)
                {
                    return (all_children_count);  //找到了当前节点的结束位置
                }
                else
                {
                    break;  //属于当前节点的子节点
                }
                temp_item = temp_item->parent();
            }
            all_children_count++;
            ite_item++;
        }
    }
    qDebug() << "所有的子节点:" << all_children_count - 1;
    return (all_children_count - 1);   //返回获取到的子节点数量,去除"当前节点本身"
}

 

  • 7
    点赞
  • 47
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
### 回答1: 如果你想遍历一个 `QTreeWidget` 中的所有节点,可以使用 `QTreeWidget` 的 `invisibleRootItem()` 方法获取根节点,然后递归遍历每个节点。 以下是一个遍历所有节点并输出它们文本的示例代码: ```python def traverse_tree(tree_item): # 输出当前节点的文本 print(tree_item.text(0)) # 遍历子节点 for i in range(tree_item.childCount()): child = tree_item.child(i) traverse_tree(child) # 获取根节点 root = tree_widget.invisibleRootItem() # 遍历根节点下的所有节点 traverse_tree(root) ``` 其中,`traverse_tree()` 是一个递归函数,它接受一个 `QTreeWidgetItem` 对象作为参数。首先输出当前节点的文本,然后遍历它的每个子节点并递归调用 `traverse_tree` 函数。 注意,在调用 `traverse_tree()` 函数时要传入根节点。 ### 回答2: QTreeWidget 是一个用于构建树形显示的控件,它是基于模型-视图模式的。要遍历 QTreeWidget 中的所有模型(即树节点),我们可以使用递归的方法来实现。 首先,我们可以通过 QTreeWidget 的 topLevelItemCount() 函数获取顶层节点的数量。然后,使用 for 循环遍历每一个顶层节点。 在循环中,可以使用 topLevelItem() 函数获取每一个顶层节点。接着,使用子节点数量的函数 childCount() 获取该顶层节点的子节点数量,同样可以使用 for 循环遍历每一个子节点。 在子节点的循环中,可以使用 child() 函数获取每一个子节点。对于每一个子节点,我们可以使用 data() 函数获取其数据,该数据包括节点的文本和其他用户定义的数据。如果我们只关心节点的文本,可以使用 text() 函数直接获取节点的文本。 在遍历子节点之后,我们可以使用 QTreeWidgetItem 的 childCount() 函数判断该节点是否还有子节点。如果有,我们可以递归调用自身来遍历下一层子节点,直到遍历完所有节点为止。 最后,可以在每一层节点的循环之后执行其他操作,比如打印节点文本,将节点文本保存到一个列表中等等。 需要注意的是,如果 QTreeWidget 中有太多的节点,递归调用可能会导致栈溢出的问题。为了避免这种情况,可以考虑使用迭代方式或者遍历模型的方法,比如使用 QTreeWidgetItemIterator。 总之,使用递归的方式可以遍历 QTreeWidget 中的所有模型,并对每一个模型执行相应的操作。 ### 回答3: QTreeWidgetQt框架中的一个小部件,用于显示和编辑树结构数据。要遍历所有模型(model)的话,首先我们需要了解QTreeWidget中的模型是如何组织的。 QTreeWidget的模型由一个根节点和其下的一组子节点组成,每个子节点又可以有自己的子节点。这个数据模型类似于树的数据结构。 遍历QTreeWidget中的所有模型,可以使用递归遍历的方法。以下是一个示例代码: ```python def traverse_model(item): if item is None: return # 打印当前节点的文本 print(item.text(0)) # 遍历当前节点的子节点 for i in range(item.childCount()): child = item.child(i) traverse_model(child) # 遍历QTreeWidget的所有根节点的子节点 for i in range(treeWidget.topLevelItemCount()): root_item = treeWidget.topLevelItem(i) traverse_model(root_item) ``` 以上代码定义了一个递归函数`traverse_model`,该函数接收一个节点作为输入,并递归遍历该节点的子节点。在遍历过程中,我们可以根据具体的需求对每个节点进行相应的处理,比如打印节点的文本或执行其他操作。 遍历QTreeWidget的所有模型时,我们首先获取所有的根节点数量,并使用`topLevelItem`方法获取每个根节点。然后将每个根节点传递给`traverse_model`函数进行遍历。 通过以上方法,我们可以遍历QTreeWidget中的所有模型,并针对每个模型执行相应的操作。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值