仿QFileSystemModel将文件目录在QTreeView中显示

2024-05-11 06:48

本文主要是介绍仿QFileSystemModel将文件目录在QTreeView中显示,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

因为工作需要显示指定文件下的文件夹下的目录,但是QFileSystemModely不熟重写的时候没有达到指定的效果,所以用其他方法做了个类似的:

void MainWindow::refreshTree()
{
    QString path ="X:/XXXX/XXXX/Tencent Files";
    newfile= new FileTree();   //设置根节点信息
    QStringList strlist = path.split("/");
    QString name = strlist.at(strlist.count() - 1);
    newfile->setFileName(name);  //文件名
    newfile->setPathName(path);  //文件路径
    GetAllFileFolder(NULL, path);//递归获取文件目录并将目录按层保存
    appendNode(NULL, m_PFile);  //添加到treeView
}
void MainWindow::GetAllFileFolder(FileTree* pfile, QString dirPath)
{
    QDir dir(dirPath);
    FileTree* file;  //自定义用来保存文件信息
    QFileInfoList folder_list = dir.entryInfoList(QDir::Dirs | QDir::NoDotAndDotDot);
    for(int i = 0; i != folder_list.size(); i++)
    {
        if(folder_list.at(i).fileName() == "." || folder_list.at(i).fileName() == "..") continue;
        QString name = folder_list.at(i).absoluteFilePath();
        file = new FileTree();
        QString fileName = folder_list.at(i).fileName();
        QString pathName = folder_list.at(i).filePath();
        file->setFileName(fileName);
        file->setPathName(pathName);
         addNode(pfile, file);  
        GetAllFileFolder(file, name);
    }
}
void MainWindow::addNode(FileTree *aPFile, FileTree *afile) //保存节点
{
    FileTree* file = aPFile;
    if(m_PFile == NULL)
    {
        m_PFile = newfile;
    }
    if(file == NULL)
    {       
        file = m_PFile;
    }else{
    }   
    file->addSubIten(afile);
}
void MainWindow::appendNode(QStandardItem *pitem, FileTree *node)
{
    QStandardItem* item = new QStandardItem;
    item->setText(node->fileName());
    item->setData(qVariantFromValue((int)(node)), Qt::UserRole);
    if (pitem == NULL)
    {
        m_itemModel->appendRow(item);
    }else{
        pitem->appendRow(item);
    }
    for(int i = 0; i <node->itemCount(); i++)
    {
        appendNode(item, node->at(i));
    }
}

效果图:

缺点是不能实时监测指定文件夹下目录的变化,所以初始化的时候获取目录总个数开个线程利用定时器判断目录个数是否发生变化,然后重新刷新组织树

下载:https://download.csdn.net/download/u010304326/10824828

这篇关于仿QFileSystemModel将文件目录在QTreeView中显示的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/978799

相关文章

第10章 中断和动态时钟显示

第10章 中断和动态时钟显示 从本章开始,按照书籍的划分,第10章开始就进入保护模式(Protected Mode)部分了,感觉从这里开始难度突然就增加了。 书中介绍了为什么有中断(Interrupt)的设计,中断的几种方式:外部硬件中断、内部中断和软中断。通过中断做了一个会走的时钟和屏幕上输入字符的程序。 我自己理解中断的一些作用: 为了更好的利用处理器的性能。协同快速和慢速设备一起工作

安卓链接正常显示,ios#符被转义%23导致链接访问404

原因分析: url中含有特殊字符 中文未编码 都有可能导致URL转换失败,所以需要对url编码处理  如下: guard let allowUrl = webUrl.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed) else {return} 后面发现当url中有#号时,会被误伤转义为%23,导致链接无法访问

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

lvgl8.3.6 控件垂直布局 label控件在image控件的下方显示

在使用 LVGL 8.3.6 创建一个垂直布局,其中 label 控件位于 image 控件下方,你可以使用 lv_obj_set_flex_flow 来设置布局为垂直,并确保 label 控件在 image 控件后添加。这里是如何步骤性地实现它的一个基本示例: 创建父容器:首先创建一个容器对象,该对象将作为布局的基础。设置容器为垂直布局:使用 lv_obj_set_flex_flow 设置容器

C# dateTimePicker 显示年月日,时分秒

dateTimePicker默认只显示日期,如果需要显示年月日,时分秒,只需要以下两步: 1.dateTimePicker1.Format = DateTimePickerFormat.Time 2.dateTimePicker1.CustomFormat = yyyy-MM-dd HH:mm:ss Tips:  a. dateTimePicker1.ShowUpDown = t

开发板NFS挂载文件目录

文章目录 序NFS1. 安装 NFS 服务器和客户端在服务器上(NFS 服务器端)在客户端上(NFS 客户端) 2. 配置 NFS 服务器创建共享目录编辑 `/etc/exports` 文件启动 NFS 服务 3. 在客户端挂载 NFS 共享创建挂载点挂载 NFS 共享验证挂载 4. 设置开机自动挂载5. 解决权限问题 序 本节主要实现虚拟机(服务器)与开发板(客户端)通过N

小程序button控件上下边框的显示和隐藏

问题 想使用button自带的loading图标功能,但又不需要button显示边框线 button控件有一条淡灰色的边框,在控件上了样式 border:none; 无法让button边框隐藏 代码如下: <button class="btn">.btn{border:none; /*一般使用这个就是可以去掉边框了*/} 解决方案 发现button控件有一个伪元素(::after

MFC中Spin Control控件使用,同时数据在Edit Control中显示

实现mfc spin control 上下滚动,只需捕捉spin control 的 UDN_DELTAPOD 消息,如下:  OnDeltaposSpin1(NMHDR *pNMHDR, LRESULT *pResult) {  LPNMUPDOWN pNMUpDown = reinterpret_cast(pNMHDR);  // TODO: 在此添加控件通知处理程序代码    if

微信小程序uniappvue3版本-控制tabbar某一个的显示与隐藏

1. 首先在pages.json中配置tabbar信息 2. 在代码根目录下添加 tabBar 代码文件 直接把微信小程序文档里面的四个文件复制到自己项目中就可以了   3. 根据自己的需求更改index.js文件 首先我这里需要判断什么时候隐藏某一个元素,需要引入接口 然后在切换tabbar时,改变tabbar当前点击的元素 import getList from '../

gazebo 已加载模型但无法显示

目录 写在前面的话问题一:robot_state_publisher 发布机器人信息失败报错一 Error: Error document empty.报错二 .xcaro 文件中有多行注释成功启动 问题二:通过 ros2 启动 gazebo 失败成功启动 问题三:gazebo 崩溃和无法显示模型问题四: 缺少 robot_description 等话题正确的输出 写在前面的话