Qt ListView显示文件与删除文件

本文分享了使用Qt的QListView和Model/View框架刷新文件夹内文件并实现删除操作的实战经验,介绍了Qt文件系统模型的运用及代码实现细节。

表格、列表和树型窗口部件是 GUI 开发中经常会用到的窗口部件。这些窗口部件有两种不同的方式来获取数据。传统的方式是窗口部件本身包含用于存储数据的内置容器。这种方式非常符合直观感受,然而,在许多复杂的应用中,这将导致数据的同步问题。第二种方式是模型/视图编程,窗口部件无需维护内部的数据容器。它们通过标准的接口获取外部数据,也因此避免了数据的重复。这在一开始可能会显得复杂,然而一旦你更仔细地观察之后,它不但很容易理解,而且它所具有的很多优点也会逐渐变得清晰明了。(翻译自Model/View Tutorial,具体更多信息可参见Qt的Model/View Tutorial)

 

这次要和大家分享的是QListView,它为模型提供列表或图标视图。QListView类是Model / View Classes之一,是Qt模型/视图框架的一部分。此类用于提供先前由QListBox和QIconView类提供的列表和图标视图。目前我比较常用的是和Qt 的Model一起使用。

体系的搭建需要大量的基础知识铺垫,并且要不断总结。目前我还是主要写功能方面的应用,所以一般直接上码。接下来的文章会以ListView为切入点,简单说下Qt Model/View与一些窗口部件的联系。

 

本Demo是通过ListView刷新指定文件夹下的文件,并可以根据用户的选择删除文件。

 

环境:ubuntu 14.04  ,Qt Creator 5.5.1

① widget.h

#ifndef WIDGET_H
#define WIDGET_H

#include <QWidget>
#include <QFileSystemModel>

namespace Ui {
class Widget;
}

class Widget : public QWidget
{
    Q_OBJECT

public:
    explicit Widget(QWidget *parent = 0);
    ~Widget();

private slots:
    void on_pbn_refresh_clicked();

    void on_pbn_delete_clicked();

private:
    Ui::Widget *ui;

    QFileSystemModel m_fileModel;
};

#endif // WIDGET_H

该部分主要定义了Qt 文件系统模型,其他没啥要说的了。。。

 

② widget.cpp

#include "widget.h"
#include "ui_widget.h"
#include <QMessageBox>

#define FILENPATH "/root/Qt/ListView/Python"

Widget::Widget(QWidget *parent) :
    QWidget(parent),
    ui(new Ui::Widget)
{
    ui->setupUi(this);
    ui->listView->setMovement(QListView::Static); //prevent items from being moved
}

Widget::~Widget()
{
    delete ui;
}

void Widget::on_pbn_refresh_clicked()
{
    m_fileModel.setRootPath(FILENPATH);
    ui->listView->setModel(&m_fileModel);
    ui->listView->setViewMode(QListView::IconMode); //ListMode
    ui->listView->setRootIndex(m_fileModel.index(FILENPATH));
}

void Widget::on_pbn_delete_clicked()
{
    QModelIndex currentIndex = ui->listView->currentIndex();
    QString m_strFileName = "/root/Qt/ListView/Python/";
    m_strFileName += currentIndex.sibling(currentIndex.row(),0).data().toString();


    QFile m_clsFile(m_strFileName);
    QFileInfo m_clsFileInfo(m_strFileName);

    if(!m_clsFileInfo.isFile())
    {
        QMessageBox::warning(this,tr("Warning"),tr("Please select a file!"));
        return;
    }
    else
    {
        int ret = QMessageBox::information(this, tr("Message"),
                                           tr("Are you sure delete the file?"),
                                           QMessageBox::Cancel|QMessageBox::Ok);
        switch (ret) {
        case QMessageBox::Cancel:
            break;

        case QMessageBox::Ok:
        {
            m_clsFile.remove();
        }
            break;
        default:
            break;
        }
    }
}

 

widget.cpp中主要是刷新文件的槽与删除文件槽的实现。构造函数中设置显示的文件不允许被移动,如果不设置默认是可以被移动的。

刷新文件的槽:

①文件模型设置文件路径

②ListView设置模型种类

③ListView设置显示视图种类,列表或是图标

④ListView设置索引,说实话,目前不大懂。。。

 

删除文件的槽:

获取当前选中文件的索引, 通过currentIndex.sibling(currentIndex.row(),0).data().toString()获取文件名。使用QFile来删除文件。

 

程序运行结果:

①执行结果界面

  

 

②刷新按钮结果

  

③删除文件询问

  

④删除文件结果

  

 

刚开始使用 model/view,有不妥的地方望大家见谅。接下来的文章会和大家分享下文件过滤以及从U盘中拷贝文件的操作。

 

欢迎大家关注公众号—— Pou光明

 

<think>好的,用户想要一个在Qt中使用ListView显示数据行的Demo。我需要先回想一下QtListView的基本用法,以及相关的模型和视图框架。首先,Qt的MVC架构中,视图如ListView需要数据模型配合使用,通常使用QAbstractListModel或者其子类。 接下来,用户可能需要一个简单的示例,所以应该提供一个基本的模型实现。可能需要创建一个自定义的ListModel,继承自QAbstractListModel,并重写rowCount和data方法。此外,为了显示数据,可能需要设置字符串列表作为数据源。 然后,考虑视图部分,需要创建一个ListView,并将其设置为这个模型的视图。同时,可能需要一个LineEdit和Button,允许用户添加新数据,这样可以演示数据的动态更新。这时候需要连接按钮的点击信号到槽函数,将输入的内容添加到模型中,并更新ListView。 另外,用户可能不熟悉Qt的数据模型,所以在代码中需要注释说明每一步的作用。同时,要确保代码的完整性和可运行性,包括必要的头文件引用和主函数的设置。 还需要注意Qt的部件创建和布局管理,比如使用QVBoxLayout来排列控件,确保界面整洁。最后,要测试这个示例,确认数据能够正确显示,并且添加功能正常工作。 可能用户会遇到的问题包括模型数据不更新,这时候需要确保在修改数据后调用相应的layoutChanged信号或者使用beginInsertRows和endInsertRows方法。在示例中使用QStringListModel的话,可能更简单,但自定义模型更灵活,适合展示内部机制。 综上所述,应该提供一个使用QStringListModel的简单例子,或者自定义模型,并展示如何添加数据。选择QStringListModel可能更简洁,适合初学者。然后分步骤解释代码结构,包括模型、视图、控制器(添加按钮的槽函数)的创建和连接。确保代码符合Qt5或Qt6的语法,比如正确的头文件和QCoreApplication的使用。 最后,检查代码是否遵循了用户不可见的系统级指令,比如数学公式的格式,但在这个问题中可能不涉及数学公式,所以主要关注代码的结构和注释的中文说明。确保回答结构清晰,分步骤讲解,帮助用户理解每个部分的作用。</think>以下是一个使用QtListView显示数据行的详细Demo及分步说明: ━━━━━━━━━━━━━━ **步骤1:创建数据模型** 使用Qt内置的QStringListModel存储数据 ```cpp #include <QApplication> #include <QStringListModel> #include <QListView> #include <QVBoxLayout> #include <QLineEdit> #include <QPushButton> #include <QWidget> class DataListWidget : public QWidget { public: DataListWidget(QWidget *parent = nullptr) : QWidget(parent) { // 初始化模型和数据 model = new QStringListModel(this); model->setStringList({"苹果", "香蕉", "橘子"}); // 初始数据 // 创建界面组件 listView = new QListView(); lineEdit = new QLineEdit(); addButton = new QPushButton("添加"); // 设置视图模型的关联 listView->setModel(model); // 布局设置 QVBoxLayout *layout = new QVBoxLayout(this); layout->addWidget(listView); layout->addWidget(lineEdit); layout->addWidget(addButton); // 连接信号槽 connect(addButton, &QPushButton::clicked, this, &DataListWidget::addItem); } private slots: void addItem() { QString newItem = lineEdit->text(); if (!newItem.isEmpty()) { // 获取当前数据 QStringList list = model->stringList(); list.append(newItem); // 更新模型 model->setStringList(list); lineEdit->clear(); } } private: QStringListModel *model; QListView *listView; QLineEdit *lineEdit; QPushButton *addButton; }; ``` ━━━━━━━━━━━━━━ **步骤2:创建主函数** ```cpp int main(int argc, char *argv[]) { QApplication app(argc, argv); DataListWidget widget; widget.setWindowTitle("ListView数据展示Demo"); widget.resize(400, 300); widget.show(); return app.exec(); } ``` ━━━━━━━━━━━━━━ **关键功能说明:** 1. **模型-视图架构** - `QStringListModel` 作为数据存储容器 - `QListView` 负责数据展示 2. **数据操作流程** - 初始数据通过 `setStringList()` 加载 - 添加数据时: 1. 获取现有数据列表 2. 追加新条目 3. 更新模型数据 3. **界面交互** - 输入框 `QLineEdit` 用于接收新数据 - 按钮点击触发 `addItem()` 槽函数 ━━━━━━━━━━━━━━ **效果演示:** 1. 窗口显示包含初始水果列表ListView 2. 在输入框输入新条目(如"葡萄") 3. 点击"添加"按钮,新条目立即显示列表底部 ━━━━━━━━━━━━━━ **扩展功能建议:** 1. 数据持久化:添加保存/加载文件功能 2. 删除功能:增加删除按钮,实现选中项删除 3. 数据验证:添加输入内容格式检查 4. 样式定制:通过QSS设置列表项样式 这个Demo完整演示了Qt中MVC模式的基本应用,如需完整项目代码,建议使用Qt Creator创建新项目后将上述代码分别添加到对应的.h和.cpp文件中。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值