一、QFileSystemModel类的基本功能

  • QFileSystemModel提供了一个可用于访问本机文件系统的数据类型
  • QFileSystemModel可以和视图组件QTreeView、QListView、QTableView结合使用,显示文件系统的信息

二、QFileSystemModel的一些函数

//要通过QFileSystemModel获得本机的文件系统,需要用此函数为QFileSystemModel设置一个初始化根目录
QModelIndex QFileSystemModel::setRootPath(const QString &newPath);
//判断节点是不是一个目录,如果是返回真
bool QFileSystemModel::isDir(const QModelIndex &index) const;

//返回节点的目录名或者带路径的文件名
QString QFileSystemModel::filePath(const QModelIndex &index) const;

//返回描述节点类型文件。如硬盘符号是“Drivew”,文件夹是“FIle Folder”,文件则用后缀描述
QString QFileSystemModel::type(const QModelIndex &index) const;

//返回去除路径的文件名/文件夹名(节点信息)
QString QFileSystemModel::fileName(const QModelIndex &index) const;

//如果节点时文件,返回文件大小的字节数。如果文件夹,返回0
qint64 QFileSystemModel::size(const QModelIndex &index) const;

三、QDirModel类

  • 用于获取磁盘文件目录的数据模型还有一个QDirModel,其功能与QFileSystemModel类似,但是QFileSystemModel采用单独的线程获取目录文件结构。而QDirModel不使用单独的线程
  • 使用单独的线程就不会阻塞主线程,所以推荐使用QFileSystemModel

四、演示案例

  • 当点击treeView的某一项时,在ListView和TableView还有下面的groupBox中显示节点信息

Qt:24---QFileSystemModel、QDirModel数据模型_根目录


代码:

  • 在类中定义一个QFileSystemModel对象

QFileSystemModel *model;

  • 在构造函数中各个view的数据模型

model=new QFileSystemModel(this);
model->setRootPath(QDir::currentPath()); //设置根目录

ui->treeView->setModel(model); //设置数据模型
ui->listView->setModel(model); //设置数据模型
ui->tableView->setModel(model); //设置数据模型

//两个槽函数,点击treeView的一个项时,设置listVie和tableView的根节点
connect(ui->treeView,SIGNAL(clicked(QModelIndex)),ui->listView,SLOT(setRootIndex(QModelIndex)));
connect(ui->treeView,SIGNAL(clicked(QModelIndex)),ui->tableView,SLOT(setRootIndex(QModelIndex)));

  • 设置treeView的on_treeView_clicked(const QModelIndex &index)信号函数

void MainWindow::on_treeView_clicked(const QModelIndex &index)
{
ui->chkIsDir->setChecked(model->isDir(index)); //如果节点时目录,设置checkBox为选中状态

//下面设置各个label的内容
ui->LabPath->setText(model->filePath(index));
ui->LabType->setText(model->type(index));
ui->LabFileName->setText(model->fileName(index));
int sz=model->size(index)/1024;
if(sz<1024)
ui->LabFileSize->setText(QString("%1 KB").arg(sz));
else
ui->LabFileSize->setText(QString::asprintf("%.1f MB",sz/1024.0));
}