Qt QTableView和QStandardItemModel包含搜索出现的文本及隐藏顶层节点

前言

使用Qt进行开发时,树结构一般是使用QTreeWidget或使用QTreeView+QStandardItemModel结合。

查找

如果要进行查找树的所有项中,是否包含某文本,就需要遍历。

QTreeWidget查找

以下是使用QTreeWidget进行查找:

首先初始化一些树结构

cpp 复制代码
    QTreeWidget* pTW = new QTreeWidget(this);
    setCentralWidget(pTW);


    for(int i = 0; i < 3; ++i)
    {
        QTreeWidgetItem* pTWI = new QTreeWidgetItem(QStringList() << QString("%1").arg(i));
        for(int j = 0; j < 3; ++j)
        {
            QTreeWidgetItem* pTWIChild = new QTreeWidgetItem(QStringList() << QString("%1_%2").arg(i).arg(j));
            pTWI->addChild(pTWIChild);
        }
        pTW->addTopLevelItem(pTWI);
    }
    pTW->expandAll();

显示如下:

如果要查找包含2的item,代码如下:

cpp 复制代码
    QTreeWidgetItemIterator it(pTW);
    while (*it) {
        QTreeWidgetItem* pItem = *it;
        if(pItem->text(0).contains("2"))
        {
            qDebug().noquote() << "查找到 : " << pItem->text(0);
        }
        ++it;
    }


QStandardItemModel查找

但如果使用QTreeView视图显示树,查阅其帮助手册,里面并没有迭代器进行查找。但看QStandardItemModel手册,发现,其有findItems()方法。

首先初始化一些数据:

cpp 复制代码
    QTreeView* pTV = new QTreeView();
    setCentralWidget(pTV);

    QStandardItemModel* pModel = new QStandardItemModel(pTV);
    pTV->setModel(pModel);
    for(int i = 0; i < 3; ++i)
    {
        QStandardItem* pItem = new QStandardItem(QString("%1").arg(i));
        for(int j = 0; j < 3; ++j)
        {
            QStandardItem* pItemTmp = new QStandardItem(QString("%1_%2").arg(i).arg(j));
            pItem->setChild(j, pItemTmp);
        }
        pModel->setItem(i, pItem);
    }
    pTV->expandAll();

显示如下:

进行查找,主要是第二个参数的设置,设置为递归及包含查找,不然查找出问题。

cpp 复制代码
    for(auto var :pModel->findItems("2", Qt::MatchRecursive | Qt::MatchContains))
    {
        qDebug().noquote() << "查找到 : " <<  var->text();
    }


设置顶层Item隐藏

QStandardItemModel设置隐藏

cpp 复制代码
pTV->setRowHidden(0, pTV->rootIndex(), true);

设置完后,节点0被隐藏

相关推荐
啊吧怪不啊吧26 分钟前
UU远程协助迎来升级!第一期更新实测
运维·服务器·远程工作
一 乐5 小时前
婚纱摄影网站|基于ssm + vue婚纱摄影网站系统(源码+数据库+文档)
前端·javascript·数据库·vue.js·spring boot·后端
1.14(java)7 小时前
SQL数据库操作:从CRUD到高级查询
数据库
Full Stack Developme8 小时前
数据库索引的原理及类型和应用场景
数据库
cuijiecheng20188 小时前
Linux下Beyond Compare过期
linux·运维·服务器
期待のcode8 小时前
前后端分离项目 Springboot+vue 在云服务器上的部署
服务器·vue.js·spring boot
AI 智能服务8 小时前
第6课__本地工具调用(文件操作)
服务器·人工智能·windows·php
IDC02_FEIYA9 小时前
SQL Server 2025数据库安装图文教程(附SQL Server2025数据库下载安装包)
数据库·windows
辞砚技术录9 小时前
MySQL面试题——联合索引
数据库·面试
萧曵 丶10 小时前
MySQL 主键不推荐使用 UUID 的深层原因
数据库·mysql·索引